Из урока Вы узнаете, как решать 22 задание ЕГЭ по информатике: дается подробное объяснение и разбор заданий по программированию циклов и ветвлений
Содержание:
- Объяснение задания 22 ЕГЭ по информатике
- Алгоритмизация и программирование: циклы и ветвления
- Решение 22 заданий ЕГЭ по информатике
- Работа с цифрами чисел в различных системах счисления
- Задания на алгоритм Евклида и поиск НОД
22-е задание: «Программирование: циклы и ветвления»
Уровень сложности
— повышенный,
Требуется использование специализированного программного обеспечения
— нет,
Максимальный балл
— 1,
Примерное время выполнения
— 7 минут.
Проверяемые элементы содержания: Умение анализировать алгоритм, содержащий ветвление и цикл
До ЕГЭ 2021 года — это было задание № 20 ЕГЭ
Типичные ошибки и рекомендации по их предотвращению:
«Технические ошибки при ответе на это задание часто обусловлены недостаточно аккуратным выполнением арифметических операций в недесятичных системах счисления»
ФГБНУ «Федеральный институт педагогических измерений»
Задание демонстрационного варианта 2022 года ФИПИ
Алгоритмизация и программирование: циклы и ветвления
* материал рассматривается на примере языка Pascal
Для решения 22 задания необходимо рассмотреть и повторить следующие темы:
- Условный оператор if
- Цикл while или repeat
- Цикл for со счетчиком
- Операция целочисленного деления div
- Операция взятия остатка mod
Алгоритм Евклида для вычисления НОД:
Заменяем большее из двух чисел разностью большего и меньшего до тех пор, пока они не станут равны:
Пример:
Найти НОД 14 и 21 по алгоритму Евклида.
✍ Решение:
НОД (14, 21) = НОД (14, 21-14) = НОД (14, 7) = НОД (7, 7) = 7
Реализация на Паскале:
1 2 3 4 5 6 7 |
function NOD (a, b: integer): integer; begin while a <> b do if a > b then a := a - b else b := b - a; NOD := a; end; |
Решение 22 заданий ЕГЭ по информатике
Плейлист видеоразборов задания на YouTube:
Задание демонстрационного варианта 2021 года ФИПИ
Работа с цифрами чисел в различных системах счисления
22_1:
Ниже записан алгоритм.
Получив на вход число x, этот алгоритм печатает число L.
Укажите наибольшее нечетное число x, при вводе которого алгоритм печатает 53.
1 2 3 4 5 6 7 8 9 10 11 12 13 |
var x, L, M, D: integer; begin readln(x); D:=x; L:=23; M:=141; while L<=M do begin L:=L+D; M:=M-3*D; end; writeln(L); end. |
Подобные задания для тренировки
✍ Решение:
✎ Решение с использованием программирования:
Pascal:
var x, L, M, D: longint; begin x := 1000; while true do begin D := x; L := 23; M := 141; while L <= M do begin L := L + D; M := M - 3 * D; end; if (l = 53) and (x mod 2 <> 0) then begin print(x); break; end; x -= 1; end; end.
✎ Аналитическое решение:
Разберем решение по одному из возможных вариантов выполнения данного задания.
Рассмотрим алгоритм:
- Результатом программы является вывод L.
- Цикл перестанет работать, когда L станет больше M (т.к.
while L<=M
). - D в программе — это и есть искомый x (
D:=x;
). - В цикле оператор
L:=L+D
работает, как сумматор: L накапливает в себе сумму всех D, тогда как D в нашей задаче не меняется и равна введенному x. - Сумматор (L) до цикла обычно обнуляется, сделаем это: т.е. в строке 5 вместо
L:=23
представим, чтоL:=0
. Тогда и условие задачи поменяется: т.е. вместо указанного в условии числа 53 программа выводит L равное 53-23 = 30. А в условии цикла M также изменит свое значение на 141-23=118: - Так как по заданию необходимо найти наибольший x, то представим, что он равен как раз 30:
1 2 3 4 5 6 7 8 9 10 |
... L:=23; M:=141; while L<=M do // L<=118 для первой итерации begin L:=L+D; M:=M-3*D; end; writeln(L); // выводится L = 30 end. |
L = L + D => L = 0 + 30 => L = 30
30 / 2 = 15
То есть D = x = 15
D=15 1 проход 2 проход L:=L+D: 0+15=15 15+15=30 M:=M-3*D: 118-3*15=73 73-3*15 = 28 L<=M: да: 15<=73 нет: 30 > 28
Результат: 15
📹 Подробное теоретическое решение данного задания 22 ЕГЭ по информатике предлагаем посмотреть в видео уроке:
📹 YouTube здесь
📹 Видеорешение на RuTube здесь
22_9:
Ниже записан алгоритм.
Получив на вход число x, этот алгоритм печатает число L.
Укажите наибольшее нечетное число x, при вводе которого алгоритм печатает 125.
1 2 3 4 5 6 7 8 9 10 11 12 13 |
var x, L, M, D: integer; begin readln(x); D:=x; L:=17; M:=70; while L<=M do begin L:=L+2*D; M:=M+D; end; writeln(L); end. |
✍ Решение:
📹 Смотрите видео решения:
📹 YouTube здесь
📹 Видеорешение на RuTube здесь
22_2:
Ниже записан алгоритм. Получив на вход число x, этот алгоритм печатает S. Известно, что 100 ≤ x ≤ 200.
Укажите наибольшее допустимое число x, при вводе которого алгоритм распечатает 30.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 |
var x,A,B,D,S: integer; begin readln(x); B:= x; A:= 9; D:= x; S:= 0; while (D div 2)>0 do begin if (D mod 2) = 1 then S:= S + 1 else S:= S + A; D:= D div 2; end; writeln(S); end. |
Подобные задания для тренировки
✍ Решение:
-
Для начала рассмотрим алгоритм программы:
- В начале программы вводится x, две переменные — B и D присваивают значение введенного x. Переменной A присваивается значение 9, а переменная S обнуляется.
- Далее следует цикл, который зависит от переменной D (равной x): пока
x div 2 > 0
выполняется тело цикла. Т.е. пока x, деленный целочисленно на 2, больше нуля. - В теле цикла происходит увеличение переменной
S
либо на 9 (А:=9
), либо на 1 в зависимости от четности значения D. Т.е. переменнаяS
увеличивается на 9 в случае, если очередное значение D — четное и увеличивается на 1, если очередное значение D — нечетное. - В конце цикла D целочисленно делится на 2 (
D := D div 2
). - По условию программы S должно быть равно 30. Посчитаем максимальное количество итераций цикла: 2n <= 200, т.е. n = 7 (максимальное значение D — 200 — делим целочисленно на 2, пока это возможно). При этом минимальное количество итераций — 6 (2n >=100, т.е. n = 6)
- За 7 или 6 итераций цикла необходимо получить S = 30, каждую итерацию цикла, увеличивая S либо на 1, либо на 9. Рассмотрим варианты:
- Из 6 итераций имеем: 3 итерации с D — нечетным (когда
s = s + 1
) и 3 итерации с D — четным (когдаs = s + 9
) - Четность чисел в двоичной системе счисления зависит от младшего бита: если младший бит = 0, то число четное, если 1, то число нечетное. Поскольку нам необходимо найти наибольшее x, то необходимо в трех старших битах данного числа, выраженного в двоичной системе счисления, поместить 1, а в остальных трех битах разместить 0. При этом необходимо не забыть про еще один старший бит равный 1 (в итерациях его нет, т.к. это последняя единица, которая уже не удовлетворяет условию цикла: условие цикла ложно while (1 div 2) > 0 — ложь):
30 = 9 + 9 + 9 + 1 + 1 + 1 -> (получаем 6 итераций, что соответствует действительности) 30 = 9 + 9 + 12 * 1 (если взять две девятки, то цикл должен работать 14 раз (9 + 9 + [12 единиц]), а это невозможно)
11110002 = 12010 первая единица будет стоять всегда, она не участвует в итерациях цикла Проверка: 120| 0 - соответствует s + 9 60| 0 - соответствует s + 9 30| 0 - соответствует s + 9 15| 1 - соответствует s + 1 7| 1 - соответствует s + 1 3| 1 - соответствует s + 1 1|
✎ 2 способ:
-
Рассмотрим алгоритм:
- Значение искомого x присваивается сразу двум переменным B и D, но B более нигде не используется, поэтому забудем про нее. D — это x.
D mod 2
— это крайняя справа цифра числа в двоичной системе счисления (младший разряд); т.е.:
В цикле:
например, если D = 510 = 1012, то D mod 2 = 1 (101)
А = 9
);D:= D div 2
— это отсечение крайнего младшего разряда числа D в двоичной системе счисления, т.е.:если было D = 510 = 1012, то стало D = 102
while (D div 2)>0
);30 = 9 + 9 + 9 + 1 + 1 + 1 -> (получаем 6 итераций цикла)
111000
при оставшемся D = 1 условие while (1 div 2) > 0 не работает, поэтому добавляем еще старший разряд "1" таким образом, получаем число в двоичной системе: 1111000
64 32 16 8 4 2 1
1 1 1 1 0 0 0 = 64 + 32 + 16 + 8 = 12010
Результат: 120
Если что-то осталось непонятным, рекомендуем посмотреть разбор данного 22 задания на видео:
1-й длительный способ решения:
📹 YouTube здесь
📹 Видеорешение на RuTube здесь
2-й способ решения (простой и быстрый):
📹 YouTube здесь📹 Видеорешение на RuTube здесь
22_3:
Ниже записан алгоритм. Получив на вход число x, этот алгоритм печатает два числа: L и M.
Укажите наибольшее из таких чисел x, при вводе которых алгоритм печатает сначала 2, а потом 8.
1 2 3 4 5 6 7 8 9 10 11 12 13 |
var x,L,M: integer; begin readln(x); L:=0; M:=0; while x>0 do begin L:=L + 1; if M < (x mod 10) then M:=x mod 10; x:=x div 10; end; writeln(L);writeln(M); end. |
Подобные задания для тренировки
✍ Решение:
Рассмотрим алгоритм работы с L:
- В конце программы алгоритм выводит значение L, равное 2 (по условию). В цикле L — это счетчик, увеличивающийся каждую итерацию цикла (каждое прохождение цикла) на 1.
- Таким образом, цикл работает два раза.
- В цикле x постоянно уменьшается на 1 разряд, т.е. от него отсекается цифра справа (
x:=x div 10
):
например, x = 243 после выполнения x:=x div 10 получаем х = 24
Рассмотрим работу с M в цикле:
- В первую итерацию цикла М всегда заменится на значение x mod 10, так как изначально М = 0.
- Из предыдущего пункта имеем, что M — это наименьшая цифра числа:
например, x = 243 после выполнения M := x mod 10; получаем 1 шаг: М = 3 2 шаг: М = 3 3 шаг: М = 2
Рассмотрим две цифры числа x путем подстановки:
- Поскольку по условию нам нужно наибольшее x, то попробуем в единицы записать число 8:
? 9
M < (x mod 10)
не будет работать, и программа распечатает 9 (вместо 8). Т.е. 9 не походит:if M < (x mod 10) then M:=x mod 10; 1 шаг: if 0 < (9) then M:=9; 2 шаг: if 9 < (любая цифра) then ... Условие не работает, программа распечатает М = 9. Не подходит!
? 8
if M < (x mod 10) then M:=x mod 10; 1 шаг: if 0 < (8) then M:=8;
9 8 если она равна 9 (то есть число 98), то М станет = 9 (а нам необходимо, чтобы осталось 8): 1 шаг: if 0 < (8) then M:=8; 2 шаг: if 8 < 9 then ... Условие работает, программа распечатает М = 9. Не подходит!
8 8 1 шаг: if 0 < (8) then M:=8; 2 шаг: if 8 < 8 then ... Условие не работает, программа распечатает М = 8. Подходит!
Результат: 88
📹 Но лучше один раз увидеть, как говорится. Посмотрите разбор задания на видео:
📹 YouTube здесь📹 Видеорешение на RuTube здесь
22_5: Демоверсия ЕГЭ 2018 информатика:
Ниже записан алгоритм. Получив на вход число x, этот алгоритм печатает два числа: L и M.
Укажите наименьшее число x, при вводе которого алгоритм печатает сначала 5, а потом 7.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 |
var x, L, M: integer; begin readln(x); L := 0; M := 0; while x > 0 do begin M := M + 1; if x mod 2 <> 0 then L := L + 1; x := x div 2; end; writeln(L); writeln(M); end. |
Типовые задания для тренировки
✍ Решение:
-
Рассмотрим алгоритм:
- Наличие операторов
x mod 2
иx div 2
говорит о том, что эту задачу можно решать, представляя x в двоичной системе счисления. - В цикле есть счетчик M, который увеличивается на единицу и в конце программы будет соответствовать количеству итераций цикла. Таким образом, имеем 7 проходов цикла.
- Условие
if x mod 2 <> 0
проверяет на нечетность младший разряд числа в двоичной системе:
В цикле:
например, если было x = 510 = 1012,
то if x mod 2 <> 0
проверяет if 1 <> 0
x := x div 2;
отсекается младший разряд двоичного представления значения x, т.е.:если было, например, x = 510 = 1012, то стало x = 102
10011112 = 64 + 8 + 4 + 2 + 1 = 7910
✎ Способ 2 (длительный, аналитический):
- В начале программы вводится
x
, и обнуляются две переменные —L
иM
. - Далее следует цикл, который зависит от переменной x: пока
x > 0
выполняется тело цикла. - В теле цикла каждый его шаг происходит увеличение переменной M на единицу. Т.е. переменная M — это счетчик, соответственно, его значение по завершению работы цикла будет соответствовать количеству шагов (итераций) цикла.
- В конце программы печатается сначала L, потом M. Т.е. L должно быть равно 5, а M = 7. Раз M будет равно 7, то из предыдущего пункта видим, что цикл имеет 7 шагов, т.е. 7 итераций.
- L — это тоже счетчик, но из условия
if x mod 2 <> 0
видим, что счетчик L подсчитывает количество нечетных промежуточных x. Т.е. x в цикле постоянно меняется, а L проверяет x и в случае нечетного значения увеличивается на единицу. В программе L должно стать 5. - В цикле x делится целочисленно на 2:
x := x div 2
- Поскольку цикл завершит работу, когда x = 0, то последним шагом будет
x = 1 div 2 = 0
. Т.е. в предпоследнем шаге x = 1. - Решим данную задачу с конца, проследив все итерации цикла. Получается, что из предыдущего шага в следующий шаг x изменяется по двум правилам, назовем их командами:
Для начала рассмотрим алгоритм программы:
1. x*2 -> если предыдущий x - четный, например 4 div 2 - обратное действие 2*2 = 4 2. x*2+1 -> если предыдущий x - нечетный, например 5 div 2 - обратное действие 2*2+1 = 5
Результат: 79
Подробное решение 22 (20) задания демоверсии ЕГЭ 2018 года смотрите на видео:
Способ 1 (быстрый):
📹 YouTube здесь
📹 Видеорешение на RuTube здесь
Способ 2 (аналитический):
📹 YouTube здесь
📹 Видеорешение на RuTube здесь
22_6: Досрочный егэ по информатике 2018, вариант 1:
Укажите наибольшее десятичное число, при вводе которого на экране сначала напечатается 3, а затем 6.
1 2 3 4 5 6 7 8 9 10 11 12 |
var x, L, M: integer; begin readln(x); L:=0; M:=0; while x > 0 do begin L:=L + 1; if (x mod 2) <> 0 then M:= M + x mod 8; x:= x div 8; end; writeln(L); write(M); end. |
Типовые задания для тренировки
✍ Решение:
📹 Видеоразбор задания:
📹 YouTube здесь
📹 Видеорешение на RuTube здесь
22_7:
Получив на вход натуральное десятичное число х, этот алгоритм печатает два числа: L и М.
Укажите наименьшее число х, при вводе которого алгоритм печатает сначала 42, а потом 4.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
var x, L, M: integer; begin readln(x); L := 1; M := 0; while x > 0 do begin M := M + 1; if x mod 8 > 3 then L := L * (x mod 8); x := x div 8 end; writeln(L); writeln(M) end. |
✍ Решение:
-
Рассмотрим алгоритм:
- В конце программы на экран выводится сначала значение переменной L, затем M. Т.е. согласно заданию, получается что:
в конце программы: L = 42 M = 4
1. x mod 8 - младший разряд числа в 8-й системе счисления т.е., например: 568 тогда x mod 8 - это цифра 6 2. x := x div 8 - "отсекание" младшего разряда числа в 8-й системе счисления т.е., например: x = 4610 = 568 тогда x := x div 8 -> x = 510 = 58
if x mod 8 > 3 then
проверяется каждая цифра числа: если она больше трех, то выполняется действие L := L * (x mod 8);
. Дословно, это говорит о том, что L — это произведение цифр числа (в его 8-м представлении), которые больше трех.М = 4 - количество цифр числа т.е. x в 8-й системе счисления имеет 4 разряда: ? ? ? ? L = 42 произведение цифр, которые больше трех.
42 = 6 * 7
x = 10678
10678 = 56710
Результат: 567
22_8:
Укажите количество двузначных натуральных чисел, при вводе которых приведенная ниже программа напечатает число 0.
1 2 3 4 5 6 7 8 9 10 11 12 |
var i, n: longint; begin i := 0; readln(n); while (n > 0) do begin i := i + n mod 8; n := n div 8; end; writeln(i mod 7); end. |
✍ Решение:
-
✎Один из вариантов решения:
- В цикле while две операции указывают на то, что данное задание можно рассматривать при работе с числом в 8-й системе счисления:
1. n mod 8 - младший разряд числа в 8-й системе счисления т.е., например: 568 тогда n mod 8 - это цифра 6 2. n := n div 8 - "отсекание" младшего разряда числа в 8-й системе счисления т.е., например: n = 4610 = 568 тогда n := n div 8 -> n = 510 = 58
n mod 8
— младшая цифра числа, и каждую итерацию цикла от числа отсекается цифра младшего разряда, то на каждом шаге в i добавляется очередная справа цифра числа: Например: n = 2568 1) i := i + n mod 8; => i = 0 + 6 = 6 (256) 2) i := i + n mod 8; => i = 6 + 5 = 11 (256) 3) i := i + n mod 8; => i = 11 + 2 = 13 (256)
i mod 7
, т.е. остаток от деления получившейся суммы на число 7.i - сумматор цифр введенного числа n в его восьмеричном представлении n - двузначные десятичные числа (по условию) результат программы = i mod 7 = 0, т.е. остаток от деления итоговой суммы на 7 (= 0)
nmin = 1010 = 128 nmax = 9910 = 1438
16 = 1+6 = 7 (7 mod 7 = 0), 25 = 2+5 = 7 (7 mod 7 = 0), 34 = 3+4 = 7 (7 mod 7 = 0), 43 = 4+3 = 7 (7 mod 7 = 0), 52 = 5+2 = 7 (7 mod 7 = 0), 61 = 6+1 = 7 (7 mod 7 = 0), 70 = 7+0 = 7 (7 mod 7 = 0), 77 = 7+7 = 14 (14 mod 7 = 0), 106 = 1+6 = 7 (7 mod 7 = 0), 115 = 1+1+5 = 7 (7 mod 7 = 0), 124 = 1+2+4 = 7 (7 mod 7 = 0), 133 = 1+3+3 = 7 (7 mod 7 = 0), 142 = 1+4+2 = 7 (7 mod 7 = 0),
Ответ: 13
22_10:
Получив на вход натуральное число x, этот алгоритм печатает два числа: a и b. Укажите наименьшее натуральное число, при вводе которого алгоритм печатает сначала 1, а потом 9.
Паскаль:
1 2 3 4 5 6 7 8 9 10 11 12 13 |
var x, a, b: longint; begin readln(x); a := 0; b := 1; while x > 0 do begin if x mod 2 = 0 then a := a + x mod 9 else b := b * (x mod 9); x := x div 9; end; writeln(a); write(b); end. |
Бейсик:
INPUT x a=0: b=1 WHILE x>0 IF x MOD 2 = 0 THEN a = a + x MOD 9 ELSE b = b * x MOD 9 END IF x = x 9 WEND PRINT a PRINT b END |
Python:
x = int(input()) a = 0 b = 1 while x > 0: if x % 2 == 0: a = a + x % 9 else: b = b * (x % 9) x = x // 9 print(a) print(b) |
С++:
#include <iostream> using namespace std; int main() { int x, a, b; cin >> x; a = 0; b = 1; while (x > 0) { if (x%2 == 0) a += x%9; else b *= x%9; x = x / 9; } cout << a << endl << b; return 0; } |
✍ Решение:
-
Рассмотрим алгоритм.
- Программа получает на вход число x.
- В цикле, пока число x больше 0, в зависимости от того, четное ли число x выполняются действия:
- если четное, то в переменную a добавляется остаток от деления числа x на 9;
- если нечетное, то переменная b умножается на остаток от деления числа x на 9;
- x целочисленно делится на 9.
- Эти три действия в цикле — ни что иное, как работа с цифрами числа в 9-й системе счисления. Тогда, проверим значение x на четность в 9-й с.с.:
- если четное, то в переменную a добавляется крайняя справа цифра числа (остаток от деления числа x на 9);
- если нечетное, то переменная b умножается на крайнюю справа цифру числа x;
- x целочисленно делится на 9: значит, отсекаем от x в 9-й с.с. крайнюю справа цифру.
- Теперь попробуем подобрать наименьшее число x, рассматривая его пока в 9-й с.с.
if x mod 2 = 0 then a := a + x mod 9
Вспомним, что для систем счисления с нечётным основанием (наш случай, 9 — нечетное) справедливо утверждение, что число чётно тогда и только тогда, когда сумма всех его цифр чётна.
произведение цифр (b) должно быть равно 9 (если число x нечетное)
сумма цифр (a) должна быть равна 1 (если число x четное)
однозначное число: минимальное 9, но цифры 9 в 9-й с.с. нет. других вариантов получить 9 нет
двухзначное число: минимальное 33 3 + 3 = 6 (четное) => a = 0 + 3 = 3, не подходит (т.к. а=1) других вариантов получить 9 нет
трехзначное число: 1 случай: минимальное 133 1 + 3 + 3 = 7 (нечетное) => b = 1 * 3 = 3 отсекаем: x = 13 1 + 3 = 4 (четное) => a = 0 + 3 = 3, не подходит (т.к. а=1) 2 случай: следующее минимальное 313 3 + 1 + 3 = 7 (нечетное) => b = 1 * 3 = 3 отсекаем: x = 31 3 + 1 = 4 (четное) => a = 0 + 1 = 1 отсекаем: x = 3 3 (нечетное) => b = 3 * 3 = 9 отсекаем: x = 0, конец цикла
3139 = 3 * 92 + 1 * 9 + 3 = 25510
Ответ: 255
Предлагаем посмотреть видеоурок задания:
📹 YouTube здесь
📹 Видеорешение на RuTube здесь
Задания на алгоритм Евклида и поиск НОД
22_4:
Ниже записан алгоритм. Получив на вход число x, этот алгоритм печатает число M.
Известно, что x>40. Укажите наименьшее такое (т.е. большее 40) число x, при вводе которого алгоритм печатает 5.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 |
var x,L,M: integer; begin readln(x); L:=x; M:=5; if L mod 2 = 0 then M:=24; while L <> M do if L > M then L:=L-M else M:=M-L; writeln(M); end. |
✍ Решение:
Рассмотрим алгоритм:
- В начале программы запрашивается x. Переменной L присваивается значение x, а переменной M — значение 5.
- Затем в условии проверяется четность переменной L: если переменная четная, то M присваивается значение 24.
- Далее следует цикл, зависящий от переменных L и M: цикл завершится, когда L сравняется с M, т.е. согласно условию, когда L = M = 5 (так как по завершению программы на экран выводится число 5):
По завершению программы: L = M = 5
НОД (a, b) = если a > b, то НОД (a-b, b) = если b > a, то НОД (a, b-a)
if L mod 2 = 0
не будет истинным, то в цикле постоянно будет происходить действие L:=L-M
). Т.е. постоянно вычитается 5.L M 45 5 40 5 35 5 30 5 25 5 20 5 15 5 10 5 5 5
Результат: 45
Посмотрите видео-разбор данного задания:
📹 YouTube здесь
📹 Видеорешение на RuTube здесь
Сегодня посмотрим новое 22 задание из ЕГЭ по информатике 2023.
Двадцать второе задание подобного типа появилось только в этом 2022 году. Из-за этого можно предположить, что на самом экзамене дадут условие похожее на демонстрационный вариант. Нет смысла давать усложнённые задачи, если ещё не все привыкли к этому заданию.
Это задание нетрудное, достаточно пару раз сделать, чтобы понять, как решать его.
Задача (Классическая)
В файле 22.xls содержится информация о совокупности N вычислительных процессов, которые могут выполняться параллельно или последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно. Информация о процессах представлена в файле в виде таблицы. В первом столбце таблицы указан идентификатор процесса (ID), во втором столбце таблицы – время его выполнения в миллисекундах, в третьем столбце перечислены с разделителем «;» ID процессов, от которых зависит данный процесс. Если процесс является независимым, то в таблице указано значение 0.
Определите минимальное время, через которое завершится выполнение всей совокупности процессов, при условии, что все независимые друг от друга процессы могут выполняться параллельно.
Типовой пример организации данных в файле:
В данном случае независимые процессы 1 и 2 могут выполняться параллельно, при этом процесс 1 завершится через 4 мс, а процесс 2 – через 3 мс с момента старта. Процесс 3 может начаться только после завершения обоих процессов 1 и 2, то есть, через 4 мс после старта. Он длится 1 мс и закончится через 4 + 1 = 5 мс после старта. Выполнение процесса 4 может начаться только после завершения процесса 3, то есть, через 5 мс. Он длится 7 мс, так что минимальное время завершения всех процессов равно 5 + 7 = 12 мс.
Решение:
У нас есть различные процессы. Для каждого процесса известно время его выполнения (столбец B), а так же от каких процессов он зависит (столбец С).
Общее время выполнения процесса вычисляется следующим образом: процесс должен дождаться самый долгий процесс от которого он зависит, а потом выполнится сам.
Используем столбец D, чтобы вычислить окончательное время выполнения каждого процесса.
Важно помнить, что когда мы берём время процесса от которого зависит какой-то процесс, то мы должны взять это время из столбца D, т.е. уже окончательное время выполнения процесса.
Минимальное время, через которое завершится выполнение всей совокупности процессов будет равно времени самого медленного процесса.
Ответ: 44
Задача (Закрепление)
В файле 22_2.xlsx содержится информация о совокупности N вычислительных процессов, которые могут выполняться параллельно или последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно.
Информация о процессах представлена в файле в виде таблицы. В первой строке таблицы указан идентификатор процесса (ID), во второй строке таблицы — время его выполнения в миллисекундах, в третьей строке перечислены с разделителем «;» ID процессов, от которых зависит данный процесс. Если процесс является независимым, то в таблице указано значение 0.
Определите минимальное время, через которое завершится выполнение всей совокупности процессов, при условии, что все независимые друг от друга процессы могут выполняться параллельно.
Типовой пример организации данных в файле:
В данном случае независимые процессы 1 и 2 могут выполняться параллельно, при этом процесс 1 завершится через 4 мс, а процесс 2 — через 3 мс с момента старта. Процесс 3 может начаться только после завершения обоих процессов 1 и 2, то есть, через 4 мс после старта. Он длится 1 мс и закончится через 4 + 1 = 5 мс после старта. Выполнение процесса 4 может начаться только после завершения процесса 3, то есть, через 5 мс. Он длится 7 мс, так что минимальное время завершения всех процессов равно 5 + 7 = 12 мс.
Решение:
Делаем аналогично прошлой задаче!
Самый медленный процесс длится 20 мс.
Ответ: 20
Задание 22 (Демо 2022)
В файле содержится информация о совокупности N вычислительных
процессов, которые могут выполняться параллельно или последовательно.
Будем говорить, что процесс B зависит от процесса A, если для выполнения
процесса B необходимы результаты выполнения процесса A. В этом случае
процессы могут выполняться только последовательно.
Информация о процессах представлена в файле в виде таблицы. В первой
строке таблицы указан идентификатор процесса (ID), во второй строке
таблицы – время его выполнения в миллисекундах, в третьей строке
перечислены с разделителем «;» ID процессов, от которых зависит данный
процесс. Если процесс является независимым, то в таблице указано
значение 0.
Определите минимальное время, через которое завершится выполнение
всей совокупности процессов, при условии, что все независимые друг от
друга процессы могут выполняться параллельно.
Типовой пример имеет иллюстративный характер. Для выполнения
задания используйте данные из прилагаемого файла.
Решение:
Здесь есть процессы, которые зависят от других процессов. В столбце D вычислим время для всех процессов, с учётом зависимости.
Если процесс зависит от двух процессов, то время ожидания будет равно самому медленному из этих процессов.
В столбце D пишем для каждой строчки: время процесса + время ожидания самого медленного процесса, от которого зависит этот процесс (если такие есть).
Получается такая картина:
Система завершит работу, когда завершится самый медленный процесс.
Ответ: 17
ЕГЭ информатика 22 задание разбор, теория, как решать.
Анализ программы с циклами и условными операторами, (П) — 1 балл
Е22.9 В файле содержится информация о вычислительных процессов проектов P1, Р2 и P3
(Е. Джобс) В файле содержится информация о вычислительных процессов проектов P1, Р2 и P3, которые могут выполняться параллельно или последовательно. Каждый вычислительный процесс разбивается на подпроцессы. Будем говорить, что подпроцесс B зависит от подпроцесса A, если для выполнения подпроцесса B необходимы результаты выполнения подпроцесса A внутри вычислительного процесса (Р1, Р2 или Р3). В этом случае …
Читать далее
Е22.8 процессов проектов P1 и P2, которые могут выполняться параллельно или последовательно
(А. Кожевникова) В файле содержится информация о вычислительных процессов проектов P1 и P2, которые могут выполняться параллельно или последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно. Информация о процессах представлена в файле в виде таблицы. В …
Читать далее
Е22.7 В файле содержится информация о вычислительных процессов проектов P1 и P2
(Е. Джобс) В файле содержится информация о вычислительных процессов проектов P1 и P2, которые могут выполняться только последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно. Информация о процессах представлена в файле в виде таблицы. В первой …
Читать далее
Е22.6 если для выполнения процесса B необходимы результаты выполнения процесса A
(В. Шубинкин) В файле содержится информация о совокупности N вычислительных процессов, которые могут выполняться параллельно или последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно. Информация о процессах представлена в файле в виде таблицы. В первом …
Читать далее
Е22.5 N вычислительных процессов, которые могут выполняться параллельно или последовательно
(Л. Евич) В файле содержится информация о совокупности N вычислительных процессов, которые могут выполняться параллельно или последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно. Информация о процессах представлена в файле в виде таблицы. В первом …
Читать далее
Е22.4 Будем говорить, что процесс B зависит от процесса A
(В. Шубинкин) В файле содержится информация о совокупности N вычислительных процессов, которые могут выполняться параллельно или последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно. Информация о процессах представлена в файле в виде таблицы. В первом …
Читать далее
Е22.3 Определите максимально возможное целочисленное t (время выполнения процесса)
В файле содержится информация о совокупности N вычислительных процессов, которые могут выполняться параллельно или последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно. Информация о процессах представлена в файле в виде таблицы. В первом столбце таблицы …
Читать далее
Е22.2 Определите минимальное время, через которое завершится выполнение всей совокупности процессов
(Л. Евич) В файле содержится информация о совокупности N вычислительных процессов, которые могут выполняться параллельно или последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно. Информация о процессах представлена в файле в виде таблицы. В первом …
Читать далее
Е22.1 В файле содержится информация о совокупности N вычислительных процессов
В файле содержится информация о совокупности N вычислительных процессов, которые могут выполняться параллельно или последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно. Информация о процессах представлена в файле в виде таблицы. В первом столбце таблицы …
Читать далее
Автор материалов — Лада Борисовна Есакова.
Поиск количества программ по результату
Задачу такого типа можно решить, построив подробное дерево всех возможных вариантов наборов команд и подсчитав те, которые приведут к нужному результату. Однако, это очень длинный и объемный способ. Его использование может привести к вычислительным ошибкам, а при большой длине программы построение дерева вообще практически невозможно.
Рассмотрим более эффективный метод подсчета количества программ.
Пример 1.
У исполнителя Увеличитель две команды, которым присвоены номера:
1. прибавь 2,
2. умножь на 3.
Первая из них увеличивает число на экране на 2, вторая — умножает его на 3.
Программа для Увеличителя — это последовательность команд. Сколько есть программ, которые число 1 преобразуют в число 31?
Ответ обоснуйте.
Решение:
Заполним таблицу со следующими столбцами:
«Число» — перечень всех чисел от 1 до 31;
«Числа-источники» — числа, из которых одной из указанных команд можно получить текущее число;
«Количество способов» — количество способов, которыми можно получить текущее число из чисел-источников. Равно сумме значений «Кол-во способов» чисел-источников.
Заметим, что никаким набором указанных команд невозможно получить четное число из 1, значит, четные числа можем в таблице не рассматривать вообще.
Число |
Числа-источники |
Кол-во способов получения |
1 | 1 | 1 |
3 | 1 | 2 |
5 | 3 | 2 |
7 | 5 | 2 |
9 | 3 ; 7 | 2+2=4 |
11 | 9 | 4 |
13 | 11 | 4 |
15 | 5 ; 13 | 2+4=6 |
17 | 15 | 6 |
19 | 17 | 6 |
21 | 7 ; 19 | 2+6=8 |
23 | 21 | 8 |
25 | 23 | 8 |
27 | 9 ; 25 | 4+8=12 |
29 | 27 | 12 |
31 | 29 | 12 |
Число 1 нам дано, т.е. его можно получить единственным способом: ничего не делая.
Число 3 можно получить из 1 двумя способами: командой 1. и командой 2. И т.д.
Заметим, что два источника могут быть только у чисел, кратным трем. Это наблюдение поможет нам быстро заполнить таблицу, т.к. количество способов увеличивается, когда рассматриваем число, кратное трем.
Например, число 9 можно получить из числа 3 и числа 7. Сложив количество способов получения чисел 3 и 7 (2+2=4), получим количество способов получения числа 9.
Полная таблица приведена для наглядности, можно было заполнить только строки с числами, кратными 3, т.к. только они меняют количество способов получения числа.
Для числа 31 получаем количество способов 12. Это и есть искомое количество программ.
Ответ: 12
Пример 2.
У исполнителя Арифметик две команды, которым присвоены номера:
1. прибавь 1,
2. прибавь 3.
Первая из них увеличивает на 1 число на экране, вторая увеличивает это число на 3.
Программа для Арифметика — это последовательность команд.
Сколько существует программ, которые число 2 преобразуют в число 15?
Решение:
Заполним таблицу со следующими строками:
«Число» — перечень всех чисел от 2 до 15;
«Числа-источники» — числа, из которых одной из указанных команд можно получить текущее число;
«Количество способов» — количество способов, которыми можно получить текущее число из чисел-источников. Равно сумме значений «Кол-во способов» чисел-источников.
Число |
Числа-источники |
Кол-во способов получения |
2 | 2 | 1 |
3 | 2 | 1 |
4 | 3 | 1 |
5 | 2 ; 4 | 1+1=2 |
6 | 3 ; 5 | 1+2=3 |
7 | 4 ; 6 | 1+3=4 |
8 | 5 ; 7 | 2+4=6 |
9 | 6 ; 8 | 3+6=9 |
10 | 7 ; 9 | 4+9=13 |
11 | 8 ; 10 | 6+13=19 |
12 | 9 ; 11 | 9+19=28 |
13 | 10 ; 12 | 13+28=41 |
14 | 11 ; 13 | 19+41=60 |
15 | 12 ; 14 | 28+60=88 |
Для числа 15 получаем количество способов 88. Это и есть искомое количество программ.
Ответ: 88
Пример 3.
Исполнитель Май15 преобразует число на экране. У исполнителя есть две команды, которым присвоены номера:
1. Прибавить 1
2. Умножить на 2
Первая команда увеличивает число на экране на 1, вторая умножает его на 2.
Программа для исполнителя Май15 – это последовательность команд. Сколько существует программ, для которых при исходном числе 2 результатом является число 29 и при этом траектория вычислений содержит число 14 и не содержит числа 25? Траектория вычислений программы – это последовательность результатов выполнения всех команд программы. Например, для программы 121 при исходном числе 7 траектория будет состоять из чисел 8, 16, 17.
Решение:
Заполним таблицу со следующими строками:
«Число» — перечень всех чисел от 2 до 29;
«Числа-источники» — числа, из которых одной из указанных команд можно получить текущее число;
«Количество способов» — количество способов, которыми можно получить текущее число из чисел-источников. Равно сумме значений «Кол-во способов» чисел-источников.
Число |
Числа-источники |
Кол-во способов получения |
2 | 2 | 1 |
3 | 2 | 1 |
4 | 2 ; 3 | 1+1=2 |
5 | 4 | 2 |
6 | 3 ; 5 | 1+2=3 |
7 | 6 | 3 |
8 | 4 ; 7 | 2+3=5 |
9 | 8 | 5 |
10 | 5 ; 9 | 2+5=7 |
11 | 10 | 7 |
12 | 6 ; 11 | 3+7=10 |
13 | 12 | 10 |
14 | 7 ; 13 | 3+10=13 |
15 | 14 | 13 |
16 | 15 | 13 |
17 | 16 | 13 |
18 | 17 | 13 |
19 | 18 | 13 |
20 | 19 | 13 |
21 | 20 | 13 |
22 | 21 | 13 |
23 | 22 | 13 |
24 | 23 | 13 |
25 | ||
26 | ||
27 | ||
28 | 14 | 13 |
29 | 28 | 13 |
До строки с числом 15 считаем все способы получения чисел. Начиная с числа 16 и до числа 24 (включительно) числа-источники 8-12 и способ получения числа применением команды «Умножить на 2» не подходят, т.к. траектория вычисления не содержит число 14. Для этих чисел учитываем одно число-источник (предыдущее) и один способ получения – «Прибавить 1».
Числа 25 вообще не должно быть в траектории, а значит, числа 26 и 27 получить невозможно.
Для числа 28 существует одно число-источник (14).
Для числа 29 получаем количество способов 13. Это и есть искомое количество программ.
Ответ: 13
Спасибо за то, что пользуйтесь нашими публикациями.
Информация на странице «Задача №22. Перебор вариантов.» подготовлена нашими редакторами специально, чтобы помочь вам в освоении предмета и подготовке к экзаменам.
Чтобы успешно сдать необходимые и поступить в высшее учебное заведение или техникум нужно использовать все инструменты: учеба, контрольные, олимпиады, онлайн-лекции, видеоуроки, сборники заданий.
Также вы можете воспользоваться другими материалами из данного раздела.
Публикация обновлена:
09.03.2023
Пройти тестирование по этим заданиям
Вернуться к каталогу заданий
Версия для печати и копирования в MS Word
1
В файле содержится информация о совокупности N вычислительных процессов, которые могут выполняться параллельно или последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно.
Информация о процессах представлена в файле в виде таблицы. В первом столбце таблицы указан идентификатор процесса (ID), во втором столбце таблицы — время его выполнения в миллисекундах, в третьем столбце перечислены с разделителем «;» ID процессов, от которых зависит данный процесс. Если процесс является независимым, то в таблице указано значение 0.
Типовой пример организации данных в файле:
ID процесса B | Время выполнения процесса B (мс) |
ID процесса(ов) A |
---|---|---|
1 | 4 | 0 |
2 | 3 | 0 |
3 | 1 | 1; 2 |
4 | 7 | 3 |
Определите минимальное время, через которое завершится выполнение всей совокупности процессов, при условии, что все независимые друг от друга процессы могут выполняться параллельно.
Выполните задания, используя данные из файла ниже:
Задание 22
Источник: Демонстрационная версия ЕГЭ−2023 по информатике
2
В файле 22_1.xlsx содержится информация о совокупности N вычислительных процессов, которые могут выполняться параллельно или последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно.
Информация о процессах представлена в файле в виде таблицы. В первой строке таблицы указан идентификатор процесса (ID), во второй строке таблицы — время его выполнения в миллисекундах, в третьей строке перечислены с разделителем «;» ID процессов, от которых зависит данный процесс. Если процесс является независимым, то в таблице указано значение 0.
Определите минимальное время, через которое завершится выполнение всей совокупности процессов, при условии, что все независимые друг от друга процессы могут выполняться параллельно.
Типовой пример организации данных в файле:
ID процесса B | Время выполнения процесса B (мс) | ID процесса(ов) A |
---|---|---|
1 | 4 | 0 |
2 | 3 | 0 |
3 | 1 | 1;2 |
4 | 7 | 3 |
В данном случае независимые процессы 1 и 2 могут выполняться параллельно, при этом процесс 1 завершится через 4 мс, а процесс 2 — через 3 мс с момента старта. Процесс 3 может начаться только после завершения обоих процессов 1 и 2, то есть, через 4 мс после старта. Он длится 1 мс и закончится через 4 + 1 = 5 мс после старта. Выполнение процесса 4 может начаться только после завершения процесса 3, то есть, через 5 мс. Он длится 7 мс, так что минимальное время завершения всех процессов равно 5 + 7 = 12 мс.
3
В файле 22_2.xlsx содержится информация о совокупности N вычислительных процессов, которые могут выполняться параллельно или последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно.
Информация о процессах представлена в файле в виде таблицы. В первой строке таблицы указан идентификатор процесса (ID), во второй строке таблицы — время его выполнения в миллисекундах, в третьей строке перечислены с разделителем «;» ID процессов, от которых зависит данный процесс. Если процесс является независимым, то в таблице указано значение 0.
Определите минимальное время, через которое завершится выполнение всей совокупности процессов, при условии, что все независимые друг от друга процессы могут выполняться параллельно.
Типовой пример организации данных в файле:
ID процесса B | Время выполнения процесса B (мс) | ID процесса(ов) A |
---|---|---|
1 | 4 | 0 |
2 | 3 | 0 |
3 | 1 | 1;2 |
4 | 7 | 3 |
В данном случае независимые процессы 1 и 2 могут выполняться параллельно, при этом процесс 1 завершится через 4 мс, а процесс 2 — через 3 мс с момента старта. Процесс 3 может начаться только после завершения обоих процессов 1 и 2, то есть, через 4 мс после старта. Он длится 1 мс и закончится через 4 + 1 = 5 мс после старта. Выполнение процесса 4 может начаться только после завершения процесса 3, то есть, через 5 мс. Он длится 7 мс, так что минимальное время завершения всех процессов равно 5 + 7 = 12 мс.
4
В файле 22_3.xlsx содержится информация о совокупности N вычислительных процессов, которые могут выполняться параллельно или последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно.
Информация о процессах представлена в файле в виде таблицы. В первой строке таблицы указан идентификатор процесса (ID), во второй строке таблицы — время его выполнения в миллисекундах, в третьей строке перечислены с разделителем «;» ID процессов, от которых зависит данный процесс. Если процесс является независимым, то в таблице указано значение 0.
Определите минимальное время, через которое завершится выполнение всей совокупности процессов, при условии, что все независимые друг от друга процессы могут выполняться параллельно.
Типовой пример организации данных в файле:
ID процесса B | Время выполнения процесса B (мс) | ID процесса(ов) A |
---|---|---|
1 | 4 | 0 |
2 | 3 | 0 |
3 | 1 | 1;2 |
4 | 7 | 3 |
В данном случае независимые процессы 1 и 2 могут выполняться параллельно, при этом процесс 1 завершится через 4 мс, а процесс 2 — через 3 мс с момента старта. Процесс 3 может начаться только после завершения обоих процессов 1 и 2, то есть, через 4 мс после старта. Он длится 1 мс и закончится через 4 + 1 = 5 мс после старта. Выполнение процесса 4 может начаться только после завершения процесса 3, то есть, через 5 мс. Он длится 7 мс, так что минимальное время завершения всех процессов равно 5 + 7 = 12 мс.
5
В файле 22_4.xlsx содержится информация о совокупности N вычислительных процессов, которые могут выполняться параллельно или последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно.
Информация о процессах представлена в файле в виде таблицы. В первой строке таблицы указан идентификатор процесса (ID), во второй строке таблицы — время его выполнения в миллисекундах, в третьей строке перечислены с разделителем «;» ID процессов, от которых зависит данный процесс. Если процесс является независимым, то в таблице указано значение 0.
Определите минимальное время, через которое завершится выполнение всей совокупности процессов, при условии, что все независимые друг от друга процессы могут выполняться параллельно.
Типовой пример организации данных в файле:
ID процесса B | Время выполнения процесса B (мс) | ID процесса(ов) A |
---|---|---|
1 | 4 | 0 |
2 | 3 | 0 |
3 | 1 | 1;2 |
4 | 7 | 3 |
В данном случае независимые процессы 1 и 2 могут выполняться параллельно, при этом процесс 1 завершится через 4 мс, а процесс 2 — через 3 мс с момента старта. Процесс 3 может начаться только после завершения обоих процессов 1 и 2, то есть, через 4 мс после старта. Он длится 1 мс и закончится через 4 + 1 = 5 мс после старта. Выполнение процесса 4 может начаться только после завершения процесса 3, то есть, через 5 мс. Он длится 7 мс, так что минимальное время завершения всех процессов равно 5 + 7 = 12 мс.
Пройти тестирование по этим заданиям
Алгоритм решения
22 задания из ЕГЭ по информатике 2023г. с помощью Python.
1. Первоначально
копируем данные из файла Excel в блокнот (файл txt)
2. Создаем
массив: arr = [0]
, в который будем записывать максимальное время по процессам, а сами
номера процессов будут индексами этого процесса
3. Открываем
наш текстовый файл (путь к файлу прописываем):
f
= open(r‘C:UsersяDesktop0
Шкурин Д.НЕГЭЕГЭ 2023Задание 2222-25.txt‘)
4. Делаем
цикл по строкам (когда мы копировали в текстовый файл, у нас данные разделены
табуляцией s.split(‘t‘)):
for s
in f.readlines():
number, time, need = s.split(‘t’)
5.
Добавим нулевой элемент в массиве:
arr.append(0)
6. Делаем
цикл по номеру процесса, причем номер процесса (если их несколько «6;5;7;4;3»)
у нас разделен «;», что мы и учитываем need.split(‘;’):
for j in need.split(‘;’):
7.
Выбираем максимальный элемент нашего массива, причем мы из текста
делаем число int(number):
arr[int(number)] =
max(arr[int(number)], arr[int(j)])
8. Когда
выбрано максимальное значение процесса мы плюсуем к нему текущее значение
(потому что процессы связанные, один процесс может начаться только тогда, когда
предыдущий закончится):
arr[int(number)]
+= int(time)
9. Печатаем
максимальный элемент созданного нами массива, это и будет ответ:
print(max(arr))
А это наша
программа целиком:
arr = [0]
f = open(r’C:UsersяDesktop0 Шкурин Д.НЕГЭЕГЭ 2023Задание 2222-25.txt’)
for
s
in
f.readlines():
number, time, need = s.split(‘t‘)
arr.append(0)
for
j
in
need.split(‘;’):
arr[int(number)] = max(arr[int(number)], arr[int(j)])
arr[int(number)] += int(time)
print(max(arr))
Статьи
Среднее общее образование
Информатика
Предлагаем вашему вниманию разбор задания №22 ЕГЭ 2019 года по информатике и ИКТ. Этот материал содержит пояснения и подробный алгоритм решения, а также рекомендации по использованию справочников и пособий, которые могут понадобиться при подготовке к ЕГЭ.
26 марта 2019
ЕГЭ-2020. Информатика. Тематические тренировочные задания
Пособие содержит задания, максимально приближенные к реальным, используемым на ЕГЭ, но распределенные по темам в порядке их изучения в 10-11-х классах старшей школы. Работая с книгой, можно последовательно отработать каждую тему, устранить пробелы в знаниях, а также систематизировать изучаемый материал. Такая структура книги поможет эффективнее подготовиться к ЕГЭ.
Купить
Демоверсия КИМ ЕГЭ-2019 по информатике не претерпела никаких изменений по своей структуре по сравнению с 2018 годом. Это значимо упрощает работу педагога и, конечно, уже выстроенный (хочется на это рассчитывать) план подготовки к экзамену обучающегося.
Мы рассмотрим решение предлагаемого проекта (на момент написания статьи – пока еще проекта) КИМ ЕГЭ по информатике.
Часть 1
Ответами к заданиям 1–23 являются число, последовательность букв или цифр, которые следует записать в БЛАНК ОТВЕТОВ № 1 справа от номера соответствующего задания, начиная с первой клеточки, без пробелов, запятых и других дополнительных символов. Каждый символ пишите в отдельной клеточке в соответствии с приведёнными в бланке образцами.
Задание 22
Исполнитель Вычислитель преобразует число, записанное на экране. У исполнителя есть три команды, которым присвоены номера:
- Прибавить 2
- Умножить на 2
- Прибавить 3
Первая из них увеличивает число на экране на 2, вторая умножает его на 2, третья увеличивает его на 3.
Программа для Вычислителя – это последовательность команд.
Сколько существует таких программ, которые преобразуют исходное число 2 в число 22 и при этом траектория вычислений программы содержит число 11?
Траектория вычислений программы – это последовательность результатов выполнения всех команд программы. Например, для программы 123 при исходном числе 7 траектория будет состоять из чисел 9, 18, 21.
Ответ: ___________________________.
Решение
Для начала решим задачу просто, без учета дополнительного условия «содержит число 11»:
Программа короткая, а также она не дает в своей траектории вычисления значения 11. И тут стоит разбить задачу на две небольшие задачи: определить число путей от 2 до 11 и от 11 до 22. Итоговый результат, очевидно, будет соответствовать произведению этих двух значений. Построение сложных схем с деревьями – нерациональная трата времени на экзамене. Чисел в нашем диапазоне не так много, поэтому предлагаю рассмотреть следующий алгоритм:
Выпишем все числа от стартового и до последнего включительно. Под первым напишем 1. Двигаясь слева направо, рассмотрим число способов попадания в текущую позицию, используя данные нам команды.
Сразу можно убрать очевидные позиции, не влияющие на решение: 3 можно зачеркнуть – понятно, что в нее нельзя попасть из стартовой позиции, используя одну из доступных нам команд; 10 – через нее мы не можем никак попасть в нашу промежуточную, а главное, обязательную позицию 11.
В 4 мы можем попасть двумя путями-командами: х2 и +2, т.е. через 4 проходят 2 пути. Напишем это значение под 4. В 5 можно попасть единственным способом: +3. Напишем под 5 значение 1. В 6 можно попасть единственным путем – через 4. А под ней у нас указано значение 2. Соответственно, именно по этим двум путям, проходя 4, мы попадем из 2 в 6. Пишем под 6 значение 2. В 7 можно попасть из двух предыдущих позиций, используя имеющиеся у нас команды, и для получения числа путей, которые нам доступны для попадания в 7, мы сложим числа, которые указывали под этими предыдущими позициями. Т.е. в 7 мы попадаем 2 (из-под 4) + 1 (из-под 5) = 3 путями. Действуя по этой схеме и далее, получаем:
Перейдем в правую половину от условного центра – 11. Только теперь при расчете будем учитывать только те пути, которые проходят через этот центр.
Двигаясь и далее слева направо, мы получаем искомый результат – 100.
Ответ: 100.
#ADVERTISING_INSERT#