Как решить 22 задачу егэ информатика

Из урока Вы узнаете, как решать 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:
  • 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.
  • Так как по заданию необходимо найти наибольший x, то представим, что он равен как раз 30:
  • L = L + D => L = 0 + 30 => L = 30 
    
  • Но число 30 — четное, а по условие необходимо нечетное x.
  • Значит, одного прохождения цикла недостаточно.
  • Предположим, что цикл имеет две итерации. За два прохождения цикла L увеличится на 2*D, то есть нужно взять такое D, чтобы 2*D было равно 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
    
  • Т.е. D=15 полностью подходит, и это наибольшее возможное число при данных условиях.

Результат: 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.

Подобные задания для тренировки

✍ Решение:

✎ 1 способ (аналитический):
 

    Для начала рассмотрим алгоритм программы:

  1. В начале программы вводится x, две переменные — B и D присваивают значение введенного x. Переменной A присваивается значение 9, а переменная S обнуляется.
  2. Далее следует цикл, который зависит от переменной D (равной x): пока x div 2 > 0 выполняется тело цикла. Т.е. пока x, деленный целочисленно на 2, больше нуля.
  3. В теле цикла происходит увеличение переменной S либо на 9 (А:=9), либо на 1 в зависимости от четности значения D. Т.е. переменная S увеличивается на 9 в случае, если очередное значение Dчетное и увеличивается на 1, если очередное значение Dнечетное.
  4. В конце цикла D целочисленно делится на 2 (D := D div 2).
  5. По условию программы S должно быть равно 30. Посчитаем максимальное количество итераций цикла: 2n <= 200, т.е. n = 7 (максимальное значение D — 200 — делим целочисленно на 2, пока это возможно). При этом минимальное количество итераций — 6 (2n >=100, т.е. n = 6)
  6. За 7 или 6 итераций цикла необходимо получить S = 30, каждую итерацию цикла, увеличивая S либо на 1, либо на 9. Рассмотрим варианты:
  7. 30 = 9 + 9 + 9 + 1 + 1 + 1  ->  (получаем 6 итераций, что соответствует действительности)
    30 =  9 + 9 + 12 * 1 (если взять две девятки, то цикл должен работать 14 раз 
    (9 + 9 + [12 единиц]), а это невозможно)
    
  8. Из 6 итераций имеем: 3 итерации с D — нечетным (когда s = s + 1) и 3 итерации с D — четным (когда s = s + 9)
  9. Четность чисел в двоичной системе счисления зависит от младшего бита: если младший бит = 0, то число четное, если 1, то число нечетное. Поскольку нам необходимо найти наибольшее x, то необходимо в трех старших битах данного числа, выраженного в двоичной системе счисления, поместить 1, а в остальных трех битах разместить 0. При этом необходимо не забыть про еще один старший бит равный 1 (в итерациях его нет, т.к. это последняя единица, которая уже не удовлетворяет условию цикла: условие цикла ложно while (1 div 2) > 0 — ложь):
  10. 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)
  • в цикле есть сумматор S, результат которого выводится в программе (результат 30), и который накапливает в себя значения по следующему принципу:
  • если указанная крайняя цифра = 1, то в S добавляется 1, если крайняя цифра = 0, то в S добавляется 9 (А = 9);
  • последнее действие цикла D:= D div 2 — это отсечение крайнего младшего разряда числа D в двоичной системе счисления, т.е.:
  • если было D = 510 = 1012, то стало D = 102
  • условие цикла: пока D при целочисленном делении на 2 больше 0 (while (D div 2)>0);
  • анализ алгоритма показывает, что вводимый x можно рассматривать в двоичной системе счисления. Поскольку сумматор S выводит в результате число 30, то можно понять, как накапливается это число в S:
  • 30 = 9 + 9 + 9 + 1 + 1 + 1  ->  (получаем 6 итераций цикла)
  • поскольку цифра 9 прибавлялась 3 раза и единица прибавлялась 3 раза, значит, в двоичной записи исходного числа D было 3 цифры 0 и три цифры 1. Чтобы получить наибольшее x, как указано в задании, расположим в старших битах единицы, а в младших 0:
  • 111000
  • важно не забыть крайнюю слева цифру 1, которая останется не учтенной в цикле, так как условие при последней единице не выполняется:
  • при оставшемся 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
    
  • Так как цикл работает два раза, значит x — двухзначное число, т.е. после двух проходов (итераций) цикла условие цикла перестало работать (x стало <= 0).

Рассмотрим работу с M в цикле:

  • В первую итерацию цикла М всегда заменится на значение x mod 10, так как изначально М = 0.
  • Из предыдущего пункта имеем, что M — это наименьшая цифра числа:
  • например, x = 243
    после выполнения M := x mod 10; получаем
    1 шаг: М = 3
    2 шаг: М = 3
    3 шаг: М = 2 
    
  • В результате работы программы на экран выводится М = 8.

Рассмотрим две цифры числа 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:
  • ? 8
  • После первой итерации цикла M = 8 (по условию нам подходит):
  • if M  < (x mod 10) then
          M:=x mod 10;
    1 шаг: 
    if 0  < (8) then
          M:=8;
    
  • Теперь рассмотрим первую цифру числа x:
  • 9 8
    если она равна 9 (то есть число 98), 
    то М станет = 9 (а нам необходимо, чтобы осталось 8):
    
    1 шаг: 
    if 0  < (8) then
          M:=8;
    2 шаг:
    if 8 < 9 then ... 
    Условие работает, программа распечатает М = 9. Не подходит!
    
  • Возьмем цифру 8 (88):
  • 8 8
    1 шаг: 
    if 0  < (8) then
          M:=8;
    2 шаг:
    if 8 < 8 then ... 
    Условие не работает, программа распечатает М = 8. Подходит!
    
  • Наибольшее х = 88.

Результат: 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.

  
Типовые задания для тренировки

✍ Решение:

✎ Способ 1:

    Рассмотрим алгоритм:

    В цикле:

  • Наличие операторов 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
    
  • Если в младшем разряде стоит единица (в двоичной системе число состоит только из 1 и 0), то срабатывает счетчик L, который увеличивается на единицу.
  • В строке x := x div 2; отсекается младший разряд двоичного представления значения x, т.е.:
  • если было, например, x = 510 = 1012, то стало x = 102
    
  • Таким образом, счетчик L подсчитывает количество единиц в двоичной записи числа. Так как в результате выводится L = 5, то в двоичной записи числа 5 единиц.
  • Так как цикл работает 7 раз, и в каждой итерации от числа в двоичной записи отсекается один разряд, то имеем 7 разрядов (цифр) в числе.
  • Итого, в двоичной записи 5 единиц и 2 нуля. Для получения наименьшего x (по заданию) расположим цифры следующим образом:
  • 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
    
  • Так как L в результате равно 5, значит, в программе 5 команд № 2 и 2 команды №1 (7-5 = 2)
  • Нарисуем дерево команд и получающиеся значения, начиная с последней итерации цикла до начальной итерации. Т.е. начнем с завершения цикла, когда x стал = 0:
  • 18 задание егэ информатика демоверсия 2018 решение

  • Вниз уходят команды, дающие четные значения x, а вверх — нечетные. Поскольку нам необходимо найти наименьший x, то «выгоднее» проследить нижние ветви дерева, т.к. они в результате дают меньшие значения.
  • Из дерева видим, что первая команда — это команда 2. В итоге осталось 4 команды № 2 и 2 команды № 1.
  • Нам выгодно с самого начала «двигаться» по дереву, используя команды №1 (чтобы x был наименьшим). Поэтому вторая и третья ветвь будут соответствовать команде №1. Поскольку первых команд должно быть только две, остальные команды будут №2.
  • Итого получаем следующий путь по дереву, в результате которого x становится равным 79.

Результат: 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
    
  • В цикле while две операции указывают на то, что данное задание проще рассматривать при работе с числом в 8-й системе счисления:
  • 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
     
  • Таким образом, в цикле рассматриваются цифры числа в 8-й системе счисления. В конце цикла, каждый раз от числа «отсекается» крайний разряд, тем самым число теряет цифру. Цикл выполняется до тех пор, пока есть цифры в числе (while x > 0).
  • М — это счетчик итераций, т.е. шагов цикла, т.к. М увеличивается каждый раз на единицу. Поскольку количество цифр числа уменьшается с каждой итерацией, то М в результате возвращает количество цифр числа — по заданию М = 4. Значит, число x — четырехзначное.
  • В условии if x mod 8 > 3 then проверяется каждая цифра числа: если она больше трех, то выполняется действие L := L * (x mod 8);. Дословно, это говорит о том, что L — это произведение цифр числа (в его 8-м представлении), которые больше трех.
  • Таким образом соберем все выводы:
  • М = 4 - количество цифр числа т.е.
    x в 8-й системе счисления имеет 4 разряда: ? ? ? ?
    L = 42 произведение цифр, которые больше трех.
    
  • По заданию нам необходимо найти наименьшее x. Теперь, зная, что х — четырехзначное, а 42 — произведение его цифр, больших трех, найдем, как получается 42:
  • 42 = 6 * 7 
    
  • Соответственно, для старшего разряда поставим единицу, а один разряд оставим равным 0:
  • x = 10678
  • Осталось перевести получившееся число в 10-ю систему счисления, чтобы найти исходный x:
  • 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
     
  • Таким образом, в цикле рассматриваются цифры числа в 8-й системе счисления. В конце цикла, каждый раз от числа «отсекается» крайний разряд, тем самым число теряет цифру. Цикл выполняется до тех пор, пока есть цифры в числе (while n > 0).
  • i — это сумматор, который аккумулирует (суммирует) цифры восьмеричного числа: поскольку 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)
    
  • Поскольку в условии говорится о десятичных числах, т.е. вводятся двузначные десятичные числа. Рассмотрим максимальное и минимальное двухзначное десятичное число, преобразованное в 8-ю систему счисления:
  • nmin = 1010 = 128
    nmax = 9910 = 1438
     
  • Выберем суммы цифр чисел в диапазоне от 12 до 143 (исключая цифры большие 7, т.к. 8-я с.с):
  • 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.

Ответ: 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;
  • if x mod 2 = 0 then
      a := a + x mod 9
  • если нечетное, то переменная b умножается на остаток от деления числа x на 9;
  • x целочисленно делится на 9.
  • Эти три действия в цикле — ни что иное, как работа с цифрами числа в 9-й системе счисления. Тогда, проверим значение x на четность в 9-й с.с.:
  • если четное, то в переменную a добавляется крайняя справа цифра числа (остаток от деления числа x на 9);
  • если нечетное, то переменная b умножается на крайнюю справа цифру числа x;
  • x целочисленно делится на 9: значит, отсекаем от x в 9-й с.с. крайнюю справа цифру.
  • Теперь попробуем подобрать наименьшее число x, рассматривая его пока в 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, конец цикла
    
  • Результаты нас устраивают (a = 1, b = 9). Переведем число 313 из 9-й с.с. в 10-ю:
  • 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
    
  • Кроме того, по условию известно, что x > 40.
  • В цикле из переменной большего значения вычитается переменная меньшего значения (алгоритм Евклида поиска наибольшего общего делимого):
  • НОД (a, b) = если a > b, то НОД (a-b, b) = если b > a, то НОД (a, b-a)
    
  • Поскольку в результате работы программы распечатывается значение M, равное 5, то можно утверждать, что если условие if L mod 2 = 0 не будет истинным, то в цикле постоянно будет происходить действие L:=L-M). Т.е. постоянно вычитается 5.
  • Исходя из предыдущего пункта, исходное число x должно быть кратно 5, так как в результате печатается 5 (M). А при M=24 алгоритм не выдаст в результате значение 5.
  • Первое наименьшее число, кратное 5 и большее 40 (по условию) — это 45.
  • Проверим по алгоритму:
  • L  M
    
    45 5
    40 5
    35 5
    30 5
    25 5
    20 5
    15 5
    10 5
    5  5 
    
  • Если следовать алгоритму Евклида, то число 5 (результат) — это наибольший общий делитель числа 5 (исходное значение M) и числа x (введенного числа). Поскольку x больше 40, то наименьшим значением для которого общим делителем с числом 5 будет само число 5 — это число 45.

Результат: 45

Посмотрите видео-разбор данного задания:

📹 YouTube здесь

📹 Видеорешение на RuTube здесь


Сегодня посмотрим новое 22 задание из ЕГЭ по информатике 2023.

Двадцать второе задание подобного типа появилось только в этом 2022 году. Из-за этого можно предположить, что на самом экзамене дадут условие похожее на демонстрационный вариант. Нет смысла давать усложнённые задачи, если ещё не все привыкли к этому заданию.

Это задание нетрудное, достаточно пару раз сделать, чтобы понять, как решать его.

Задача (Классическая)

В файле 22.xls содержится информация о совокупности N вычислительных процессов, которые могут выполняться параллельно или последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно. Информация о процессах представлена в файле в виде таблицы. В первом столбце таблицы указан идентификатор процесса (ID), во втором столбце таблицы – время его выполнения в миллисекундах, в третьем столбце перечислены с разделителем «;» ID процессов, от которых зависит данный процесс. Если процесс является независимым, то в таблице указано значение 0.

Определите минимальное время, через которое завершится выполнение всей совокупности процессов, при условии, что все независимые друг от друга процессы могут выполняться параллельно.

Типовой пример организации данных в файле:

ЕГЭ по информатике - Задание 22

В данном случае независимые процессы 1 и 2 могут выполняться параллельно, при этом процесс 1 завершится через 4 мс, а процесс 2 – через 3 мс с момента старта. Процесс 3 может начаться только после завершения обоих процессов 1 и 2, то есть, через 4 мс после старта. Он длится 1 мс и закончится через 4 + 1 = 5 мс после старта. Выполнение процесса 4 может начаться только после завершения процесса 3, то есть, через 5 мс. Он длится 7 мс, так что минимальное время завершения всех процессов равно 5 + 7 = 12 мс.

Решение:

У нас есть различные процессы. Для каждого процесса известно время его выполнения (столбец B), а так же от каких процессов он зависит (столбец С).

Общее время выполнения процесса вычисляется следующим образом: процесс должен дождаться самый долгий процесс от которого он зависит, а потом выполнится сам.

Используем столбец D, чтобы вычислить окончательное время выполнения каждого процесса.

ЕГЭ по информатике - Задание 22 (Решение)

Важно помнить, что когда мы берём время процесса от которого зависит какой-то процесс, то мы должны взять это время из столбца D, т.е. уже окончательное время выполнения процесса.

Минимальное время, через которое завершится выполнение всей совокупности процессов будет равно времени самого медленного процесса.

Ответ: 44

Задача (Закрепление)

В файле 22_2.xlsx содержится информация о совокупности N вычислительных процессов, которые могут выполняться параллельно или последовательно. Будем говорить, что процесс B зависит от процесса A, если для выполнения процесса B необходимы результаты выполнения процесса A. В этом случае процессы могут выполняться только последовательно.

Информация о процессах представлена в файле в виде таблицы. В первой строке таблицы указан идентификатор процесса (ID), во второй строке таблицы  — время его выполнения в миллисекундах, в третьей строке перечислены с разделителем «;» ID процессов, от которых зависит данный процесс. Если процесс является независимым, то в таблице указано значение 0.

Определите минимальное время, через которое завершится выполнение всей совокупности процессов, при условии, что все независимые друг от друга процессы могут выполняться параллельно.

Типовой пример организации данных в файле:

ЕГЭ по информатике - Задание 22 (Закрепление)

В данном случае независимые процессы 1 и 2 могут выполняться параллельно, при этом процесс 1 завершится через 4 мс, а процесс 2  — через 3 мс с момента старта. Процесс 3 может начаться только после завершения обоих процессов 1 и 2, то есть, через 4 мс после старта. Он длится 1 мс и закончится через 4 + 1 = 5 мс после старта. Выполнение процесса 4 может начаться только после завершения процесса 3, то есть, через 5 мс. Он длится 7 мс, так что минимальное время завершения всех процессов равно 5 + 7 = 12 мс.

Решение:

Делаем аналогично прошлой задаче!

ЕГЭ по информатике - Задание 22 (Закрепление, Решение)

Самый медленный процесс длится 20 мс.

Ответ: 20

Задание 22 (Демо 2022)

В файле содержится информация о совокупности N вычислительных
процессов, которые могут выполняться параллельно или последовательно.
Будем говорить, что процесс B зависит от процесса A, если для выполнения
процесса B необходимы результаты выполнения процесса A. В этом случае
процессы могут выполняться только последовательно.

Информация о процессах представлена в файле в виде таблицы. В первой
строке таблицы указан идентификатор процесса (ID), во второй строке
таблицы – время его выполнения в миллисекундах, в третьей строке
перечислены с разделителем «;» ID процессов, от которых зависит данный
процесс. Если процесс является независимым, то в таблице указано
значение 0.

ЕГЭ по информатике демоверсия 2023 - задание 22

Определите минимальное время, через которое завершится выполнение
всей совокупности процессов, при условии, что все независимые друг от
друга процессы могут выполняться параллельно.

Типовой пример имеет иллюстративный характер. Для выполнения
задания используйте данные из прилагаемого файла.

Решение:

Здесь есть процессы, которые зависят от других процессов. В столбце D вычислим время для всех процессов, с учётом зависимости.

Если процесс зависит от двух процессов, то время ожидания будет равно самому медленному из этих процессов.

В столбце D пишем для каждой строчки: время процесса + время ожидания самого медленного процесса, от которого зависит этот процесс (если такие есть).

Получается такая картина:

ЕГЭ по информатике демоверсия 2023 - задание 22 решение

Система завершит работу, когда завершится самый медленный процесс.

Ответ: 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(rC: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. Информатика. Тематические тренировочные задания

ЕГЭ-2020. Информатика. Тематические тренировочные задания

Пособие содержит задания, максимально приближенные к реальным, используемым на ЕГЭ, но распределенные по темам в порядке их изучения в 10-11-х классах старшей школы. Работая с книгой, можно последовательно отработать каждую тему, устранить пробелы в знаниях, а также систематизировать изучаемый материал. Такая структура книги поможет эффективнее подготовиться к ЕГЭ.

Купить

Демоверсия КИМ ЕГЭ-2019 по информатике не претерпела никаких изменений по своей структуре по сравнению с 2018 годом. Это значимо упрощает работу педагога и, конечно, уже выстроенный (хочется на это рассчитывать) план подготовки к экзамену обучающегося.

Мы рассмотрим решение предлагаемого проекта (на момент написания статьи – пока еще проекта) КИМ ЕГЭ по информатике.

Часть 1

Ответами к заданиям 1–23 являются число, последовательность букв или цифр, которые следует записать в БЛАНК ОТВЕТОВ № 1 справа от номера соответствующего задания, начиная с первой клеточки, без пробелов, запятых и других дополнительных символов. Каждый символ пишите в отдельной клеточке в соответствии с приведёнными в бланке образцами.

Задание 22

Исполнитель Вычислитель преобразует число, записанное на экране. У исполнителя есть три команды, которым присвоены номера:

  1. Прибавить 2
  2. Умножить на 2
  3. Прибавить 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#

Понравилась статья? Поделить с друзьями:
  • Как решить 20 задание егэ математика базовый
  • Как решить 2 задание егэ по информатике через python
  • Как решить 2 задание егэ по информатике через excel
  • Как решить 2 задание егэ по географии
  • Как решить 2 задание егэ информатика 2022