Главная Посты Курсы Связь О сайте

ЕГЭ по информатике 2022 - Задание 5 (Линейный алгоритм)



Привет! В этой статье будут различные примеры решения задач из 5-ого задания ЕГЭ по информатике 2022.


Задание 5 решается не сложно, но, как всегда, нужно потренироваться решать подобные задачи, чтобы уверенно себя чувствовать на ЕГЭ по информатике 2022.


Рассмотрим классический пример.



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

На вход алгоритма подаётся натуральное число N. Алгоритм строит по нему новое число R по следующему принципу.

1) Строится двоичная запись числа N.
2) К этой записи дописываются справа ещё два разряда по следующему правилу:
а) Складываются все цифры двоичной записи, и остаток от деления суммы на 2 дописываются в конец числа (справа). Например, запись 11100 преобразуется в запись 111001.
б) Над этой записью производятся те же действия - справа дописывается остаток от деления суммы цифр на 2.

Полученная таким образом запись (в ней на два разряда больше, чем в записи исходного числа N) является двоичной записью искомого числа R.

Укажите минимальное число R, которое превышает 42 и может являться результатом работы алгоритма. В ответе это число запишите в десятичной системе.


Решение:

Алгоритму на вход приходит обычное натуральное число N.


Это число преобразуется в двоичную запись (пункт 1).


ЕГЭ по информатике 2022 - задание 5 (Представление числа в двоичной форме)

Во втором пункте правил формирования нового числа сказано, что к числу, полученному в первом пункте, дописываются справа ещё два дополнительных разряда.


ЕГЭ по информатике 2022 - задание 5 (Представление числа в двоичной форме)


Про 1 дополнительный разряд указано в подпункте а): "Складываются все цифры двоичной записи, и остаток от деления суммы на 2 дописываются в конец числа (справа). Например, запись 11100 преобразуется в запись 111001."


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


Со вторым дополнительным разрядом происходит всё тоже самое, что и с первым разрядом, только когда подсчитываем количество единиц, мы так же подсчитываем и в 1-ом дополнительном разряде.


В вопросе просят указать входящее наименьшее число N, чтобы автомат выдал число R больше 42.


Возьмём наименьшее число, которое больше 42 (т.е. 43) и переведём его в двоичную систему. Это можно сделать с помощью стандартного windows калькулятора.


Вызываем калькулятор, выбираем Вид->Программист. Кликаем на отметку Dec (это означает, что мы находимся в десятичной системе) и набираем число 43. Затем кликаем на отметку Bin


ЕГЭ по информатике 2022 - задание 5 (Переводим в двоичную систему с помощью калькулятора)


Проверим число 1010112. Может ли оно быть результатом работы нашего алгоритма?


ЕГЭ по информатике 2022 - задание 5 (Проверяем число)

Отделяем два дополнительных разряда справа. У нас, не считая двух дополнительных разрядов, количество единиц равно двум. Количество чётное, значит, в первом дополнительном разряде должен стоять 0. А у нас стоит 1.


Следовательно, число 1010112 не может являться результатом работы алгоритма. И это число не подходит.


Проверим последующие числа. На калькуляторе можно прибавлять по 1 и получать следующее число в двоичной системе. Мы проверяем последовательно числа, чтобы не пропустить самое маленькое число.


ЕГЭ по информатике 2022 - задание 5 (Проверяем числа)

Подходит число 1011102. Количество единиц без двух дополнительных разрядов равно трём. Число нечётное. Значит, в первом дополнительном разряде должна стоять 1. В этом числе как раз стоит 1.


Количество единиц вместе с дополнительным разрядом равно 4. Число чётное, значит, во втором дополнительном разряде должен стоять 0. У нас и стоит во втором дополнительном разряде 0. Следовательно, число 1011102 подходит по всем правилам и является наименьшим.


В десятичной системе это число 46.


Ответ: 46



Рассмотрим ещё одну интересную задачу для подготовки к ЕГЭ по информатике 2022.


Задача(Классическая, закрепление)

На вход алгоритма подаётся натуральное число N. Алгоритм строит по нему новое число R следующим образом.

1) Строится двоичная запись числа N.
2) Каждый разряд этой записи заменяется двумя разрядами по следующему правилу: если в разряде стоит 0, то вместо него пишется 01; если в разряде стоит 1, то 1 заменяется на 10.
Например, двоичная запись 1010 числа 10 будет преобразована в 10011001.

Полученная таким образом запись (в ней в два раза больше разрядов, чем в записи исходного числа N) является двоичной записью искомого числа R.

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



Решение:

В этой задаче в начале строится двоичная запись числа N.


ЕГЭ по информатике 2022 - задание 5 (Представление числа в двоичной форме)

Каждый разряд превращается в два разряда! Единица превращается в 10. Ноль превращается в 01. На рисунке показан пример, как будет преобразовано число 10 = 10102.


ЕГЭ по информатике 2022 - задание 5 (Алгоритм перевода)

Оценим первое число, которое меньше, чем 256. Это число 255.


255 = 111111112

Здесь количество разрядов равно 8. Это чётное число, значит, такое количество разрядов может быть в результате работы алгоритма. Только чётное количество разрядов может получится в результате работы алгоритма.


В старших двух разрядах должны быть цифры 10, т.к. исходное число N не может начинаться с нуля.


В остальных парах попробуем написать 10, чтобы число было как можно больше.


Получается, что число 101010102 удовлетворяет всем правилам алгоритма, является наибольшим, и оно меньше 256.




Но важный момент, нас просили в ответ записать нечётное число.


В двоичной системе число, которое оканчивается на ноль, является чётным.

В двоичной системе число, которое оканчивается на единицу, является нечётным.

Чтобы число было нечётным, изменим последние разряды на 01.


101010012 = 169

Ответ: 169

Набираем обороты в решении 5 задания из ЕГЭ по информатике 2022.


Задача(Классическая, закрепление)

На вход алгоритма подаётся натуральное число N. Алгоритм строит по нему новое число следующим образом.

1) Строится двоичная запись числа N.

2) К этой записи дописываются справа ещё два разряда по следующему правилу: если N чётное, в конце числа справа дописываются два нуля, в противном случае справа дописываются две единицы. Например, двоичная запись 1101 будет преобразована в 110111.

Полученная таким образом запись (в ней на два разряда больше, чем в записи исходного числа N) является двоичной записью числа - результата работы данного алгоритма.

Укажите минимальное число N, для которого результат работы алгоритма будет больше 130. В ответе это число запишите в десятичной системе счисления.



Решение:

После перевода в двоичную систему исходного числа N, алгоритм строит новое число по следующему правилу:


ЕГЭ по информатике 2022 - задание 5 (Алгоритм перевода 2)

Бордовым прямоугольником показаны дополнительные разряды.


Нужно найти минимальное число больше 130. Будем проверять последовательно числа, начиная с 131.


ЕГЭ по информатике 2022 - задание 5 (Проверяем числа 2)


Подходит число 135. В ответе нужно указать число N. Отбросим от числа 100001112 дополнительные разряды и переведём в десятичную систему.


1000012 = 33

Ответ: 33

Похожие задачи встречались в сборнике С. С. Крылова для подготовке к ЕГЭ по информатике.


Задача (Усложнённая)

На вход алгоритма подаётся натуральное число N. Алгоритм строит по нему новое число R следующим образом.

1. Из числа N вычитается остаток от деления N на 4.

2. Строится двоичная запись полученного результата.

3. К это записи справа дописываются ещё два дополнительных разряда по следующему правилу:

а) Складываются все цифры двоичной записи, и остаток от деления суммы на 2 дописываются в конец числа (справа). Например, запись 11100 преобразуется в запись 111001.

б) Над этой записью производятся те же действия - справа дописывается остаток от деления суммы цифр на 2.

Полученная таким образом запись является двоичной записью числа R.

Укажите наибольшее число N, для которого результат работы данного алгоритма меньше 47. В ответе число N укажите в десятичной системе.



Решение:

Первый способ. Число R должно быть меньше 47. Переведём число 46 в двоичную систему.


46 = 1011102

Результат от второго пункта не должен превышать 10112. Если результат от второго пункта будет превышать это число, то после добавления дополнительных разрядов получится число R, которое не меньше 47.


Проверим число 10112 = 11. Видим, что это число не может являться результатом пункта 2.


11 + 0 = 11 (остаток при делении 11 на 4 равен 3) -
11 + 1 = 12 (остаток при делении 12 на 4 равен 0) -
11 + 2 = 13 (остаток при делении 13 на 4 равен 1) -
11 + 3 = 14 (остаток при делении 13 на 4 равен 2) -

Здесь мы перебираем все остатки при делении на 4. Чтобы число 11 могло являться результатом пункта 2, число, помеченное зелёным цветом, должно совпадать с числом, помеченное оранжевым цветом. Стоит заметить, что если в первой строчке не совпадают числа, то и в остальных они тоже не совпадут. Верно и обратное. Если в первой строчке совпадут числа, то и для остальных остатков тоже числа будут совпадать.


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


10 + 0 = 10 (остаток при делении 10 на 4 равен 2) Не подходит
9 + 0 = 9 (остаток при делении 9 на 4 равен 1) Не подходит
8 + 0 = 8 (остаток при делении 8 на 4 равен 0) Подходит!

Значит, число 8 нам подходит. Число 8 - это результат работы алгоритма в первом пункте. Нас просят найти максимальное число. Следовательно, возьмём остаток 3, чтобы исходное число N было как можно больше. Тогда N будет:


N = 8 + 3 = 11

Ответ получается 11.


Второй способ. Решим задачу с помощью Python'а.


Перебираем числа от 100 до 1 с помощью цикла for. Третий параметр "-1" в цикле for говорит о том, что мы перебираем числа в обратном порядке.


for i in range(100, 0, -1):
    n = i
    n = n - n % 4 # Выполняем первый пункт
    n = format(n, 'b') # Переводим в двоичную систему
    n = n + str(n.count('1') % 2) # Подпункт a) третьего пункта
    n = n + str(n.count('1') % 2) # Подпункт б) третьего пункта
    r = int(n, 2) # Переводим из двоичной системы в десятичную
    if r < 47:
        print(i)

В этой программе запрограммировали алгоритм, который указан в задаче. Если значение переменной r (результат работы алгоритма) меньше 47, то печатаем это значение на экран. Первое распечатанное число и есть ответ к задаче.


В переменную n по очереди подставляются числа из нашего диапазона (100-1). Команда % находит остаток от деления.


Функция count, в данном случае, подсчитывает количество единиц в строке, которая находится в переменной n.


ЕГЭ по информатике 2022 - задание 5 (результат работы программы)

Ответ: 11

Боковой вариант 5-ого задания из ЕГЭ по информатике.


Задача (Лучше знать)

Автомат получает на вход четырёхзначное число. По этому числу строится новое число по следующим правилам:

1. Перемножаются первая и вторая, а также третья и четвёртая цифры исходного числа.

2. Полученные два числа записываются друг за другом в порядке убывания (без разделителей).

Пример. Исходное число: 2465. Суммы: 2 * 4 = 8; 6 * 5 = 30. Результат: 308. Укажите наибольшее число, в результате обработки которого автомат выдаст число 124.



Решение:

В подобных задачах из ЕГЭ по информатике нумерация происходит начиная со старшего разряда.


ЕГЭ по информатике 2022 - задание 5 (нумерация цифр)

Первое правило можно представить следующим образом:


ЕГЭ по информатике 2022 - задание 5 (первое правило)

Второе правило заключается в том, что мы "соединяем" два числа, полученных в первом пункте, причём, сначала идёт большее число, а затем меньшее.


Проанализируем число 124.


ЕГЭ по информатике 2022 - задание 5 (анализ числа)

Чтобы четырёхзначное число было наибольшим, выгодно, чтобы в старшем разряде стояла 9. Но, не у числа 12, не у числа 4, нет такого делителя. Какой наибольший делитель мы можем получить? Это число 6. Число 6 является делителем 12-ти. Значит, первая цифра будет 6, а вторая цифра будет 2 (6*2=12).


Рассмотрим второе число 4. Третий разряд тоже желательно сделать побольше. Значит, в четвёртый разряд поставим 4, а в младший разряд 1 (4*1=4).


Ответ получается 6241.


Ответ: 6241

Счастливых экзаменов! Видеоролик можете посмотреть ниже!






19-10-2021 в 12:31:01





Похожая статья:

ЕГЭ по информатике 2022 - Задание 10 (Поиск в тексте)

В этом уроке по подготовке к ЕГЭ по информатике 2022 разберём задание ...

Категория: ЕГЭ  Подкатегория: -
Дата: 15-01-2018 в 16:47:34 0



Оставить коментарий:



Напишите email, чтобы получать сообщения о новых комментариях (необязательно):


Задача против робота. Расположите картинки горизонтально: