509926 решу егэ

Новые тренировочные варианты ЕГЭ 2023 по математике базовый и профильный уровень с ответами и решением для 10 и 11 класса, больше 100 вариантов в формате реального экзамена ФИПИ вы можете решать онлайн или скачать.

Тренировочные варианты ЕГЭ 2023 по математике база и профиль

13.09.2022 Тренировочный вариант №1 ЕГЭ 2023 по математике профиль с ответами

20.09.2022 Тренировочный вариант №2 ЕГЭ 2023 по математике профиль с ответами

20.09.2022 Тренировочный вариант №2 ЕГЭ 2023 база по математике с ответами

27.09.2022 Математика 11 класс профиль входная мониторинговая работа 3 варианта с ответами

28.09.2022 Тренировочный вариант №3 ЕГЭ 2023 база по математике с ответами

28 сентября 2022 Статград математика 11 класс ЕГЭ 2023 база и профиль варианты и ответы

29 сентября 2022 Тренировочный вариант №3 ЕГЭ 2023 по математике профиль с ответами

1 октября 2022 Ларин вариант 399 ЕГЭ 2023 по математике профиль решение с ответами

6 октября Тренировочный вариант №4 ЕГЭ 2023 база по математике с ответами

6 октября Тренировочный вариант №4 ЕГЭ 2023 по математике профиль с ответами

8 октября Ларин вариант 400 ЕГЭ 2023 по математике профиль решение с ответами

12 октября Тренировочный вариант №5 ЕГЭ 2023 база по математике с ответами

12 октября Тренировочный вариант №5 ЕГЭ 2023 по математике профиль с ответами

14 октября Вариант 1 Ященко ЕГЭ 2023 математика профиль с ответами и решением

14 октября Вариант 2 Ященко ЕГЭ 2023 математика профиль с ответами и решением

15 октября Ларин вариант 401 ЕГЭ 2023 по математике профиль решение с ответами

15 октября Ларин вариант 402 ЕГЭ 2023 по математике профиль решение с ответами

16 октября Вариант 3 Ященко ЕГЭ 2023 математика профиль с ответами и решением

16 октября Вариант 4 Ященко ЕГЭ 2023 математика профиль с ответами и решением

23 октября Тренировочный вариант №6 ЕГЭ 2023 база по математике с ответами

24 октября Тренировочный вариант №6 ЕГЭ 2023 по математике профиль с ответами

25 октября Тренировочный вариант №7 ЕГЭ 2023 база по математике с ответами

26 октября Тренировочный вариант №7 ЕГЭ 2023 по математике профиль с ответами

28 октября Ларин вариант 403 ЕГЭ 2023 по математике профиль решение с ответами

29 октября Ларин вариант 404 ЕГЭ 2023 по математике профиль решение с ответами

1 ноября 2022 Тренировочный вариант №8 решу ЕГЭ 2023 база по математике с ответами

1 ноября 2022 Тренировочный вариант №8 решу ЕГЭ 2023 по математике профиль с ответами

5 ноября 2022 Вариант 1-2 распечатай и реши ЕГЭ 2023 база по математике 11 класс с ответами

6 ноября 2022 Ларин вариант 405 ЕГЭ 2023 профиль по математике решение с ответами

9 ноября 2022 Тренировочный вариант №9 решу ЕГЭ 2023 база по математике с ответами

12 ноября 2022 Тренировочный вариант №9 решу ЕГЭ 2023 по математике профиль с ответами

13 ноября 2022 Ларин вариант 406 ЕГЭ 2023 профиль по математике решение с ответами

15 ноября 2022 Тренировочный вариант №10 решу ЕГЭ 2023 база по математике 11 класс с ответами

15 ноября 2022 Тренировочный вариант №10 решу ЕГЭ 2023 по математике профиль с ответами

21 ноября 2022 Ларин вариант 407 ЕГЭ 2023 профиль по математике решение с ответами

23 ноября 2022 Тренировочный вариант №11 решу ЕГЭ 2023 база по математике 11 класс с ответами

23 ноября 2022 Тренировочный вариант №11 решу ЕГЭ 2023 по математике профиль с ответами

27 ноября 2022 Ларин вариант 408 ЕГЭ 2023 профиль по математике решение с ответами

28 ноября 2022 Вариант 3-4 распечатай и реши ЕГЭ 2023 база по математике 11 класс с ответами

30 ноября 2022 Мониторинговая работа по математике 11 класс ЕГЭ 2023 профиль 1 полугодие

3 декабря 2022 Тренировочный вариант №12 решу ЕГЭ 2023 база по математике 11 класс с ответами

3 декабря 2022 Тренировочный вариант №12 решу ЕГЭ 2023 по математике профиль с ответами

3 декабря 2022 Пробник ЕГЭ 2023 Москва по математике профиль задания и ответы

5 декабря 2022 Ларин вариант 409 ЕГЭ 2023 профиль по математике решение с ответами

9 декабря 2022 Тренировочный вариант №13 решу ЕГЭ 2023 база по математике 11 класс с ответами

10 декабря 2022 Тренировочный вариант №13 решу ЕГЭ 2023 профиль по математике 11 класс с ответами

12 декабря 2022 Ларин вариант 410 ЕГЭ 2023 профиль по математике решение с ответами

13 декабря 2022 Статград математика 11 класс профиль ЕГЭ 2023 варианты МА2210209-МА2210212 и ответы

13 декабря 2022 Математика 11 класс база ЕГЭ 2023 статград варианты и ответы

15 декабря 2022 Тренировочный вариант №14 решу ЕГЭ 2023 профиль по математике 11 класс с ответами

15 декабря 2022 Тренировочный вариант №14 решу ЕГЭ 2023 база по математике 11 класс с ответами

20 декабря 2022 Вариант 5-6 распечатай и реши ЕГЭ 2023 база по математике 11 класс с ответами

20 декабря 2022 Ларин вариант 411 ЕГЭ 2023 профиль по математике решение с ответами

3 января 2023 Ларин вариант 412 ЕГЭ 2023 профиль по математике решение с ответами

6 января 2023 Тренировочный вариант 1-2 ЕГЭ 2023 профиль математика задания и ответы

8 января 2023 Вариант 3-4 ЕГЭ 2023 профиль математика задания и ответы

9 января 2023 Вариант 7-8 распечатай и реши ЕГЭ 2023 база по математике 11 класс с ответами

10 января 2023 Тренировочный вариант №15 и №16 решу ЕГЭ 2023 профиль по математике 11 класс с ответами

11 января 2023 ЕГЭ 2023 математика тренировочные задания и ответы Ященко, Семенов

11 января 2023 Тренировочный вариант №15 и №16 база ЕГЭ 2023 по математике 11 класс с ответами

19 января 2023 Тренировочные варианты №17 и №18 решу ЕГЭ 2023 профиль по математике 11 класс с ответами

22 января 2023 Ларин вариант 413 и 414 ЕГЭ 2023 профиль по математике решение и ответы

22 января 2023 Тренировочный 19 вариант решу ЕГЭ 2023 профиль по математике 11 класс с ответами

22 января 2023 База ЕГЭ 2023 математика 11 класс тренировочный вариант 19 с ответами

25 января 2023 База ЕГЭ 2023 математика 11 класс тренировочный вариант 20 с ответами

27 января 2023 Тренировочный вариант №20 решу ЕГЭ 2023 профиль по математике 11 класс с ответами

28 января 2023 Вариант 415 Ларина ЕГЭ 2023 по математике 11 класс задания и ответы

2 февраля 2023 Вариант 21 база ЕГЭ 2023 математика 11 класс тренировочный вариант с ответами

2 февраля 2023 Тренировочный вариант №21 решу ЕГЭ 2023 профиль по математике 11 класс с ответами

8 февраля 2023 Математика 10-11 класс ЕГЭ 2023 статград варианты база и профиль МА2200101-МА2200110 и ответы

11 февраля 2023 Тренировочный вариант №22 решу ЕГЭ 2023 профиль по математике 11 класс с ответами

11 февраля 2023 Тренировочный вариант №22 решу ЕГЭ 2023 база по математике 11 класс с ответами

12 февраля 2023 Вариант 416 Ларина ЕГЭ 2023 по математике 11 класс задания и ответы

12 февраля 2023 Вариант 417 Ларина ЕГЭ 2023 по математике 11 класс задания и ответы

13 февраля 2023 Вариант 9 и вариант 10 ЕГЭ 2023 база математика распечатай и реши задания

13 февраля 2023 Вариант 11 и вариант 12 ЕГЭ 2023 база математика распечатай и реши

16 февраля 2023 Тренировочный вариант №23 решу ЕГЭ 2023 база по математике 11 класс с ответами

16 февраля 2023 Тренировочный вариант №23 решу ЕГЭ 2023 профиль по математике 11 класс с ответами

18 февраля 2023 Вариант 418 Ларина ЕГЭ 2023 по математике 11 класс задания и ответы

22 февраля 2023 Пробный ЕГЭ 2023 вариант 24 база по математике 11 класс с ответами

22 февраля 2023 Пробный ЕГЭ 2023 вариант 24 профиль по математике 11 класс с ответами

25 февраля 2023 Вариант 419 Ларина ЕГЭ 2023 по математике 11 класс задания и ответы

28 февраля 2023 Статград математика 11 класс ЕГЭ 2023 база и профиль и ответы

4 марта 2023 Пробник ЕГЭ 2023 вариант 25 база по математике 11 класс с ответами

4 марта 2023 Вариант 420 Ларин ЕГЭ 2023 по математике 11 класс задания и ответы

5 марта 2023 Пробник ЕГЭ 2023 вариант 25 профиль по математике 11 класс с ответами

8 марта 2023 Пробник ЕГЭ 2023 вариант 26 профиль по математике 11 класс с ответами

8 марта 2023 Пробник ЕГЭ 2023 вариант 26 база по математике 11 класс 100 баллов с ответами

Смотрите также на нашем сайте:

Сборник Ященко ЕГЭ 2023 математика профильный уровень 36 вариантов

ПОДЕЛИТЬСЯ МАТЕРИАЛОМ

Skip to content

ЕГЭ по математике — Профиль 2022. Открытый банк заданий с ответами.

ЕГЭ по математике — Профиль 2022. Открытый банк заданий с ответами.admin2022-08-27T23:17:48+03:00

Сегодня посмотрим одно из самых интересных заданий из ЕГЭ по информатике 2023. Будем решать 24 задание. В этом задании нужно работать с файлами.

Все решения задач из задания 24 ЕГЭ по информатике 2023 будут приведены на языке программирования Python (Питон).

Поехали!

Задача (Самая простая)

Текстовый файл состоит не более чем из 106 символов A, B и C. Определите максимальное количество идущих подряд символов B. Для выполнения этого задания следует написать программу. Ниже приведён файл, который необходимо обработать с помощью данного алгоритма.

Решение:

Решим данную задачу на языке Python.

f=open('24_1.txt')
s=f.read()
k=0
kmax=0

for i in range(0, len(s)):
    if s[i]=='B':
        k=k+1
        kmax=max(k, kmax)
    else:
        k=0

print(kmax)
    

С помощью команды open() подвязываемся к файлу. Чтобы не прописывать полный путь, файл должен лежать в той же папке, что и программа.

С помощью команды .read() зачитываем в переменную s всё содержимое файла.

Переменная k — это текущий счётчик символов «B». Задача переменной kmax сохранить максимальное значение k.

С помощью цикла for перебираем все символы из строки s. Переменная i пробегается по номерам всех симолов. Счёт символов начинается в строке с нуля. В начале берём нулевой символ, потом первый и т.д. Конструкция for i in range(0, len(s)) позволяет пройтись по всем символам строки до конца.

Если нам встретился нужный символ «B», то мы счётчик прибавляем на 1. Это значит, что мы подсчитываем текущую цепочку. Если будет стоять 3 символа «B» подряд, значит, счёт k покажет значение 3. Как только встретится дургой символ, то это означает, что цепочка прервалась и счётчик переводится в первоначальное положение 0.

При любом увеличении счётчика происходит анализ этого счётчика на максимальность. Функция max выбирает максимальное значение из старого значения kmax и нового показания счётчика k. Если счётчику k удалось победить kmax, то его значение будет считаться максимальным на данный момент времени.

В ответ идёт значение kmax. Это и есть длина максимальной цепочки. В этой задачке ответ получается 11.

Ответ: 11

Закрепим это простое задание из ЕГЭ по информатике 2023.

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

Текстовый файл состоит не более чем из 106 символов X, Y и Z. Определите максимальное количество идущих подряд символов, среди которых нет символа Z. Для выполнения этого задания следует написать программу.

Решение:

Решение похоже на предыдущее.

f=open('24_2.txt')
s=f.read()
k=0
kmax=0

for i in range(0, len(s)):
    if s[i]!='Z':
        k=k+1
        kmax=max(k, kmax)
    else:
        k=0

print(kmax)
    

Если нет символов «Z», то подсчитываем, иначе сбрасываем.

Задача (Обращаемся к соседу)

Текстовый файл состоит не более чем из 106 символов X, Y и Z. Определите максимальное количество идущих подряд символов, расположенных в алфавитном порядке (возможно с повторением симолов). Для выполнения этого задания следует написать программу.

Решение:

f=open('24_2.txt')
s=f.read()
k=1
kmax=0

for i in range(0, len(s)-1):
    if s[i]<=s[i+1]:
        k=k+1
        kmax=max(k, kmax)
    else:
        k=1

print(kmax)
    

В ответе получается 15. Символы можно сравнивать между собой с помощью знаков «>» или меньше «<» ( а так же «>=» или «<=»), причём это сравнение происходит в алфавитном порядке. Например, символ «B» будет больше, чем «A» и т.п. Теперь нам нужно уже обратится к соседу, уже важна связь между соседними символами. Раз мы обращаемся к следующему символу, то должны пробегать до len(s)-1, иначе куда мы будем обращаться, когда дойдём до последнего символа?

В самом начале цепочки мы анализируем два символа, а к счётчику прибавляем всего лишь 1. Чтобы это учесть, в начале счётчику (переменной k) присваиваем 1. Затем, по мере продвижения по цепочке, мы добавляем в наш анализ 1 новый символ, и к счётчику добавляется одна 1. Дальше уже таких проблем нет.

Раз мы присвоили в переменную k единицу, то и сбрасывать в ветке else мы тоже должны на 1. Эти значения обычно взаимосвязаны.

Если мы обращаемся к соседнему символу, как правило, счётчик и сброс устанавливаются в 1. Это не стопроцентная истина, но иметь ввиду это нужно.

Ответ: 15

Задача (Обращаемся к соседу, закрепление)

Текстовый файл состоит не более чем из 106 символов арабских цифр (0, 1, …,9). Определите максимальное количество идущих подряд цифр, среди которых каждые две соседние различны. Для выполнения этого задания следует написать программу.

Решение:

f=open('24_3.txt')
s=f.read()
k=1
kmax=0

for i in range(0, len(s)-1):
    if s[i]!=s[i+1]:
        k=k+1
        kmax=max(k, kmax)
    else:
        k=1

print(kmax)
    

Если соседи различны, мы подсчитываем, иначе сбрасываем.

Ответ: 120

Задача (Обращаемся к соседу, ещё сложнее)

Текстовый файл состоит не более чем из 106 символов арабских цифр (0, 1, …,9). Определите максимальное количество идущих подряд нечётных цифр, расположенных в неубывающем порядке. Для выполнения этого задания следует написать программу.

Решение:

f=open('24_3.txt')
s=f.read()
k=1
kmax=0

for i in range(0, len(s)-1):
    if s[i]<=s[i+1] and s[i] in '13579' and s[i+1] in '13579' :
        k=k+1
        kmax=max(k, kmax)
    else:
        k=1

print(kmax) 

Здесь опять можно применить знаки сравнения прям к символам. Удобно проверить принадлежность к нечётным цифрам конструкцией s[i] in ‘13579’. Нечётной цифрой должна быть как текущая, так и следующая.

Ответ: 8

Решим ещё одну тренировочную задачу из ЕГЭ по информатике 2023.

Задача (Обращаемся к соседу, ещё сложнее, закрепление)

Текстовый файл состоит не более чем из 106 символов 1, 2, 3, A, B, С. Определите максимальное количество идущих подряд символов, среди которых никакие две буквы и никакие две цифры не стоят рядом. Для выполнения этого задания следует написать программу.

Решение:

f=open('24_4.txt')
s=f.read()
k=1
kmax=0

for i in range(0, len(s)-1):
    if (s[i] in '123' and s[i+1] in 'ABC') or (s[i] in 'ABC' and s[i+1] in '123') :
        k=k+1
        kmax=max(k, kmax)
    else:
        k=1

print(kmax) 

В этой задаче цифры и буквы должны чередоваться. Если у нас цифра, то следующая должны быть буква, или наоборот, если у нас буква, то следующая должна быть цифра. В этих двух случаях прибавляем к счётчику 1.

Ответ: 20

Задача (Исключаем строку из 2-х символов, демо 2022)

Текстовый файл состоит из символов P, Q, R и S.

Определите максимальное количество идущих подряд символов
в прилагаемом файле, среди которых нет идущих подряд символов P.
Для выполнения этого задания следует написать программу.

Решение:

Напишем решение на языке Python.

f=open('24_5.txt')
s=f.read()
k=1
kmax=0

for i in range(0, len(s)-1):
    if s[i]=='P' and s[i+1]=='P':
        k=1
    else:
        k=k+1
        kmax = max(k, kmax)

print(kmax)

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

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

Мы проходим в цикле for до длины строки минус один. Значение 1 в счётчике при сбросе и в начале программы так же компенсирует и тот момент, что мы не подсчитываем последний символ!

При изменении счётчика, сохраняем максимальное значение в переменной mx

Если бы у нас была вместо PP другая комбинация, состоящая к примеру из 5 символов, то мы бы тогда в начале и при сбросе писали в счётчик значение 5-1=4.

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

В этой задаче получается ответ 188.

Ответ: 188

Задача (Исключаем подстроку из 3-х символов)

Текстовый файл состоит из символов арабских цифр(0, 1, …,9).

Определите максимальное количество идущих подряд символов
в прилагаемом файле, среди которых нет трёх символов 0, стоящих рядом.
Для выполнения этого задания следует написать программу.

Решение:

Напишем решение на языке Python.

f=open('24_6.txt')
s=f.read()
k=2
kmax=0

for i in range(0, len(s)-2):
    if s[i]=='0' and s[i+1]=='0' and s[i+2]=='0':
        k=2
    else:
        k=k+1
        kmax = max(k, kmax)

print(kmax)

Чтобы понять это решение, нужно посмотреть предыдущую задачу. Мы здесь обращаемся к двум соседям, значит, счётчик устанавливаем в 2. Так же проходим в цикле до len(s)-2. Нежелательная строка может состоять не только из одинаковых символов. Может быть строка «XYYZ», к примеру.

Ответ: 7684

Задача (Не более одного символа Z)

Текстовый файл состоит не более чем из 106 символов X, Y и Z. Определите максимальное количество идущих подряд символов, среди которых символ Z встречается не более одного раза.

Решение:

В нашей цепочке один раз можно встретиь символ Z, а два раза уже нельзя. Здесь мы применим функцию .split(). Как работает эта фнкция? Напишем тестовую программу.

s='sadqttqtreq'
a=s.split('q')
print(a)

Результат данной программы будет следующим:

[‘sad’, ‘tt’, ‘tre’, »]

Команда split «разрезает» строку по символу «q». В результате мы получаем массив с кусочками этой строки.

Решение нашей задачи.

f=open('24_7.txt')
s=f.read()
a=s.split('Z')
k=0
kmax=0

for i in range(0, len(a)-1):
  k = len(a[i]) + 1 + len(a[i+1])
  kmax = max(k, kmax)

print(kmax)

Разрезаем нашу строку по символу «Z». Пробегаемся уже по массиву a. Цепочка-кандидат это текущий кусочек (a[i]), символ Z (1) и следующий кусочек (a[i+1]).

Каждого кандитата проверяем сразу на максимальность.

Ответ: 43

Задача (Не более двух символов Z)

Текстовый файл состоит не более чем из 106 символов X, Y и Z. Определите максимальное количество идущих подряд символов, среди которых символ Z встречается не более двух раз.

Решение:

Решение аналогично предыдущему.

f=open('24_7.txt')
s=f.read()
a=s.split('Z')
k=0
kmax=0

for i in range(0, len(a)-2):
  k = len(a[i]) + 1 + len(a[i+1]) + 1 + len(a[i+2])
  kmax = max(k, kmax)

print(kmax)

Ответ: 50

Задача (Звенья)

Текстовый файл состоит не более чем из 106 символов X, Y и Z. Определите максимальную длину цепочки символов, состоящей из повторяющихся фрагментов XYZ. Цепочка должна начинаться с символа X и заканчиваться символом Z. Например, для строки ZZZXYZXYZXZZZ длина цепочки равна 6: XYZ+XYZ

Решение:

Если мы подсчитаем количество идущих подряд звеньев XYZ, то, можно сказать, дело сделано.

f=open('24_8.txt')
s=f.read()
s=s.replace('XYZ', '1')
k=0
kmax=0

for i in range(0, len(s)):
    if s[i]=='1':
        k=k+1
        kmax=max(k, kmax)
    else:
        k=0

print(kmax*3)

Мы с помощью команды replace заменили звенья на «1» (на символ, которого точно нет в файле). Теперь задача свелась к самой простой, которую мы рассматривали в начале статьи. Нужно просто подсчитать количество идущих поряд единиц.

В ответе нас просили указать количество символов, а не звеньев, поэтому переменную kmax умножаем на 3.

Ответ: 66

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

Текстовый файл состоит не более, чем из 106 символов из набора A, B, С. Найдите максимальное количество идущих пар символов AC или AB. Искомая подстрока может включать только пары AB, только пары AC или содержать одновременно как пары AC, так и пары AB.

Решение:

f=open('24_9.txt')
s=f.read()
s=s.replace('AB', '1')
s=s.replace('AC', '1')
k=0
kmax=0

for i in range(0, len(s)):
    if s[i]=='1':
        k=k+1
        kmax=max(k, kmax)
    else:
        k=0

print(kmax)

Здесь нам подходит звено, как и AB, так и AC. В ответе нужно указать количество пар, поэтому не на что умножать переменную kmax не нужно.

Ответ: 19

Задача (Звенья, основная волна 20.06.22)

Текстовый файл состоит из символов A, B, C, D и O. Определите максимальное количество идущих подряд пар символов вида согласная + гласная в прилагаемом файле. Для выполенения этого задания следует написать программу.

Решение:

f=open('24_10.txt')
s=f.read()
s=s.replace('BA', '1')
s=s.replace('CA', '1')
s=s.replace('DA', '1')
s=s.replace('BO', '1')
s=s.replace('CO', '1')
s=s.replace('DO', '1')
k=0
kmax=0

for i in range(0, len(s)):
    if s[i]=='1':
        k=k+1
        kmax=max(k, kmax)
    else:
        k=0

print(kmax)

Ответ: 174

Задача (Звенья, последнее звено неполное)

Текстовый файл состоит не более чем из 106 символов X, Y и Z. Определите максимальную длину цепочки вида XYZXYZXYZ… (составленной из фрагментов XYZ, последний фрагмент может быть неполным). Для выполнения этого задания следует написать программу. Ниже приведён файл, который необходимо обработать с помощью данного алгоритма.

Решение:

Т.к. последнее звено может быть неполным, здесь удобно применить другой алгоритм.

Пусть в начале показания счётчика равно нулю. Если мы находим нужный нам символ в нужной последовательности, то прибавляем к счётчику 1. Если последовательность сбивается, то ставим счётчик в ноль.

На рисунке представлен данный алгоритм. В нижней строке указано показание счётчика в момент анализа символа.

ЕГЭ по информатике 2021 - задание 24 (Цепочка символов)

На данном рисунке максимальная длина цепочки нужных символов равна 9.

Видим, что для символа X, когда он находится на своём месте, остаток от деления значения счётчика на 3 равен 0.

Для символа Y, когда данный символ находится на своём месте, остаток от деления значения счётчика на 3 равен 1.

Для символа Z, когда данный символ находится на своём месте, остаток от деления значения счётчика на 3 равен 2.

Мы смотрим остаток от деления на 3, потому что у нас длина звена равна трём (XYZ).

Таким образом, мы и наш анализ очередного символа привяжем к показанию счётчика:

f=open('24_11.txt')
s=f.read()
k=0
kmax=0

for i in range(0, len(s)):
    if (s[i]=='X' and k%3==0) or  (s[i]=='Y' and k%3==1) or (s[i]=='Z' and k%3==2):
        k=k+1
        kmax = max(k, kmax)
    else:
        if s[i]=='X': k=1
        else: k=0


print(kmax)

Важный момент: Если нужную цепочку прервал символ X, то нужно счётчик сразу выставить в 1, иначе может произойти такая ошибка:

ЕГЭ по информатике 2021 - задание 24 (Цепочка символов 2)

Т.е. первые три нужных символа в цепочке алгоритм не засчитал.

Поэтому мы не просто сбрасываем счётчик в ноль, а прописываем условие:

if s[i]=='X': k=1
else: k=0

Ответ: 13

Задача (Полезный приём)

Текстовый файл 24-157.txt состоит не более чем из 106 символов и содержит только заглавные буквы латинского алфавита (ABC…Z). Определите символ, который чаще всего встречается в файле между двумя одинаковыми символами. Например, в тексте CCBAABABCBC есть комбинации ABA, BAB, BCB и CBC. Чаще всего – 2 раза – между двумя одинаковыми символами стоит B, в ответе для этого случая надо написать B2 (без пробелов и других разделителей). Если таких символов несколько, выведите тот, который стоит раньше в алфавите.

Решение:

f=open('24-157.txt')
s=f.read()
a=[0]*150

for i in range(0, len(s)-2):
    if s[i]==s[i+2]:
        a[ord(s[i+1])] = a[ord(s[i+1])] + 1

ch=''
mx=0
for i in range(0, 150):
    if a[i]>mx:
        mx=a[i]
        ch=chr(i)


print(ch, mx)

Здесь мы заводим массив a. Индексы этого массива — это коды ANSI всех букв латинского алфавита (ABC…Z). Ведь, как мы знаем, каждая буква кодируется определённым числом (кодом ANSI). Вот часть этой таблицы.

ЕГЭ по информатике 2022 - задание 8 (Фрагмент таблицы ANSI)

Например, буква A кодируется кодом 65. Коды увеличиваются в алфавитном порядке на 1. Буква Z кодируется числом 90. Таким образом, 150 ячеек точно хватит для нашего алфавита. Здесь берём с запасом, потому что на экзамене можно точно не вспомнить коды, но достаточно запомнить, что 150 ячеек вполне хватит для заглавных и строчных букв латинского алфавита.

Значит, ячейка 65 отвечает за букву A, ячейка 66 отвечает за букву B и т.д. Если мы встретили букву между двумя одинаковыми буквами, то её ячейка увеличивается на 1.

Функция ord() превращает символ в код ANSI.

После того, как мы прошли всю строку и собрали информацию о наших буквах, нужно пройти массив a и найти наибольшее число в нём.

Здесь мы уже не пользуемся функцией max, а используем условие, потому что нужно кроме максимального числа тянуть ещё один параметр — сам код (переменную i). Функция chr() превращает код ANSI обратно в символ.

Ответ: W1608

Задача (Строки различной длины)

Текстовый файл 24-164.txt состоит не более чем из 106 символов и содержит только заглавные буквы латинского алфавита (ABC…Z). Текст разбит на строки различной длины. Необходимо найти строку, содержащую самую длинную цепочку стоящих подряд одинаковых букв. Если таких строк несколько, надо взять ту, которая в файле встретилась раньше. Определите, какая буква встречается в этой строке чаще всего. Если таких букв несколько, надо взять ту, которая стоит раньше в алфавите. Запишите в ответе эту букву, а затем – сколько раз она встречается во всем файле.

Пример. Исходный файл:

ZZQABA
ZALAAC
QRAQUT

В этом примере в первой и второй строках наибольшая длина цепочек одинаковых буквы равна 2 (ZZ в первой строке, AA во второй), в третьей – 1. Берём первую строку, т.к. она находится в файле раньше. В этой строке чаще других встречаются буквы Z и A (по 2 раза), выбираем букву A, т. к. она стоит раньше в алфавите. В ответе для этого примера надо записать A6, так как во всех строках файла буква A встречается 6 раз.

Решение:

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

f=open('24-164.txt')
kmax=0
count=0
n=-1
for s in f.readlines():
    count=count+1
    k=1
    for i in range(0, len(s)-1):
       if s[i]==s[i+1]:
           k=k+1
           if k>kmax:
               kmax=k
               n=count
       else:
           k=1

print(n)

Получается строка под номером 162. Переменная count считает строки по порядку. В переменную n сохраняем номер нужной строки. Опять пользуемся условием, а не функцией max, т.к. здесь нужно и обновлять kmax, и сохранять значение n. У нас условие строгое k>kmax, значит, сохранится первая строка с наибольшей искомой цепочкой.

f=open('24-164.txt')

count=0
a=[0]*150

for s in f.readlines():
    count=count+1
    k=1
    if count==162:
        for i in range(0, len(s)):
            a[ord(s[i])] = a[ord(s[i])] + 1
       
ch=''
mx=0
for i in range(0, 150):
    if a[i] > mx:
        mx=a[i]
        ch=chr(i)

print(ch)

Теперь нас интересует только строка под номером 162. Далее используем приём из прошлой задачи. Заводим массив a из 150 ячеек и используем таблицу кодов ANSI. Так определяем какая буква встретилась чаще всего в строке под номером 162. Получается буква K.

f=open('24-164.txt')
s=f.read()
print(s.count('K'))

Осталось найти количестов букв K во всём файле. Для этого используем функцию .count()

Ответ: K36582

В задаче 15 «Задача (Полезный приём)», созданы переменные k и kmax — напрасно, они не используются.

Убрал, по привычке написал.

На уроке рассмотрен материал для подготовки к ЕГЭ по информатике, разбор 24 задания. Объясняется тема о программной обработке символьной информации.

Содержание:

  • ЕГЭ по информатике 24 задание объяснение
  • Выполнение 24 задания ЕГЭ
    • Последовательности (цепочки) символов
    • Работа с числами (цифрами) в текстовом файле
    • Работа с отдельными строками файла

24-е задание: «Программная обработка символьной информации»

Уровень сложности

— повышенный,

Требуется использование специализированного программного обеспечения

— нет,

Максимальный балл

— 1,

Примерное время выполнения

— 8 минут.

  
Проверяемые элементы содержания: Умение создавать собственные программы (10–20 строк) для обработки символьной информации

Выполнение 24 задания ЕГЭ

Плейлист видеоразборов задания на YouTube:

Задание демонстрационного варианта 2022 года ФИПИ


Последовательности (цепочки) символов

24_1: Демоверсия варианта ЕГЭ по информатике 2021, ФИПИ:

  

Задание выполняется с использованием прилагаемых файлов

 
Текстовый файл состоит не более чем из 106 символов X, Y и Z.
Определите максимальное количество идущих подряд символов, среди которых каждые два соседних различны.
Для выполнения этого задания следует написать программу.

Ответ: 35
✍ Решение:

    Паскаль:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    
    var
      f: text;
      i, k, max: integer;
      s: string;
     
    begin
      assign(f, 'D:24.txt');
      reset(f);
      readln(f, s);
      max := 1;
      k := 1; // кол-во подряд идущих
      for i := 2 to length(s) do
      begin
        if s[i] <> s[i - 1] then
        begin
          inc(k);
          if k > max then max := k;
        end
        else k := 1;
      end;
      write(max)
    end.

    Python:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    
    f=open('D:/24.txt')
    s=f.readline()
    m=1
    k=1
    for i in range(1,len(s)):
        if s[i]!=s[i-1]:
            k+=1
            m=max(k,m)
        else:
            k=1
    print(m)

📹 Видеоразбор:
📹 YouTube здесь

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


24_2:

Задание выполняется с использованием прилагаемых файлов

 
В текстовом файле (выше по ссылке) находится цепочка из символов латинского алфавита A, B, C.

Найдите длину самой длинной подцепочки, состоящей из символов C.

Ответ: 0

✍ Решение:

    PascalABC.net:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    
    begin
      assign(input, 'k7-0.txt');
      var s: string;
      var c: string;
      read(s);
      c := 'C';
      while c in s do
        c := c + 'C';
      print(length(c) - 1)
    end.

    Python:
    способ 1:

    1
    2
    3
    4
    5
    6
    7
    8
    
    with open("k7-0.txt") as Fin:
      s = Fin.readline()
     
    c = 'C'
    while c in s: # ищем CC, потом CCC и т.д
      c += 'C'
    print(len(c)-1 )
    # минус 1, чтобы убрать лишнюю (последнюю добавленную С)

    способ 2:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    
    f=open('k7-0.txt')
    s = f.readline() # считали строку
    m = 0 # макс длина цепочки
    l = 0 # начальная длина цепочки
    for i in range(0,len(s)):
        if s[i]=='C':
            l+=1
            m = max(l,m) # перезаписали Макс длину
        else:
            l = 0 #  сбрасываем счетчик
    print(m)

24_3:

Задание выполняется с использованием прилагаемых файлов

 
В текстовом файле (выше по ссылке) находится цепочка из символов латинского алфавита A, B, C, D, E.

Найдите длину самой длинной подцепочки, состоящей из символов A, B или C (в произвольном порядке).

Ответ: 16

✍ Решение:

    PascalABC.net:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    
    begin
      assign(input, 'k7a-1.txt');
      var s: string;
      read(s);
      var k := 0;
      var maxim := 0;
      for var i := 1 to length(s) do
        if s[i] in 'ABC' then
        begin
          k += 1;
          if k > maxim then maxim := k
        end
        else k := 0 ;
      write(maxim)
    end.

    Python:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    
    f = open('k7a-1.txt')
    s = f.readline() # считали строку
    m = 0 # макс длина цепочки из "A,B,С"
    l = 0 # начальная длина цепочки из "A,B,С"
    for i in range(0,len(s)):
        if s[i] in'ABC':
            l+=1
            m = max(l,m) # перезаписали Макс длину
        else:
            l = 0 # другая буква - сбрасываем счетчик
    print(m)

24_4:

Задание выполняется с использованием прилагаемых файлов

 
В текстовом файле (по ссылке выше) находится цепочка из символов латинского алфавита A, B, C, D, E, F.

Найдите длину самой длинной подцепочки, не содержащей гласных букв.

Ответ: 20

✍ Решение:

    PascalABC.net:
    Вариант 1:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    
    begin
      assign(input, 'k7a-6.txt');
      var s: string;
      read(s);
      var k := 0;
      var maxim := 0;
      for var i := 1 to length(s) do
        if s[i] in 'BCDF' then
        begin
          k += 1;
          if k > maxim then maxim := k
        end
        else k := 0 ;
      write(maxim)
    end.

    Вариант 2:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    
    begin
      var s := readAllText('d:k7a-6.txt').Trim;
      var (k, max) := (0, 0);
      foreach var c in s do 
        if not (c in 'AE') then
        begin
          k += 1;
          if k > max then max := k;
        end else
          k := 0;
      print(max)
    end.

    Python:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    
    with open("k7a-6.txt") as F:
      s = F.readline() # считали строку
     
    k = 0 # начальная длина цепочки из "B,C,D,F"
    Max = 0 # макс длина цепочки из "B,C,D,F"
    for c in s:
      if c in 'BCDF':
        k += 1
        if k > Max:
          Max = k # перезаписали Макс длину
      else:
          k = 0 # другая буква - сбрасываем счетчик
    print(Max)

24_5:

Задание выполняется с использованием прилагаемых файлов

 
В текстовом файле (по ссылке выше) находится цепочка из символов латинского алфавита A, B, C, D, E.

Найдите максимальную длину цепочки вида EABEABEABE… (состоящей из фрагментов EAB, последний фрагмент может быть неполным).

Ответ: 7
✍ Решение:

    PascalABC.net:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    
    begin
      assign(input, 'k7b-1.txt');
      var s: string;
      read(s);
      var c := 'EAB';
      while c in s do
      begin
        if c[length(c)] = 'B' then
          c += 'E'
        else if c[length(c)] = 'A' then
          c += 'B'
        else if c[length(c)] = 'E' then
          c += 'A';
      end;
      print(length(c) - 1)
    end.

    Python:
    Способ 1:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    
    with open("k7b-1.txt") as Fin:
      s = Fin.readline()
     
    c = 'EAB'
    while c in s: # ищем EAB, потом EABE и т.д
        if c[-1]=="B": c +="E"
        elif c[-1]=="A": c +="B"
        elif c[-1]=="E": c +="A"
    print(len(c)-1)

    Постоянно повторяется фрагмент EAB, поэтому возможны 3 варианта окончания строки:

  • 1 тип = ..EABE — неполный последний фрагмент
  • 2 тип = ..EABEB — неполный последний фрагмент
  • 3 тип = ..EAB — полный последний фрагмент
  • Способ 2:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    
    f=open('k7b-1.txt')
    s = f.readline()
    m = 0
    i = 0
    for char in s:
        if (char == 'E' and i%3 == 0) or 
           (char == 'A' and i%3 == 1) or 
           (char == 'B'and i%3 == 2): 
            i += 1
            m = max(i,m)
        elif char == 'E':
            i = 1
        else:
            i = 0
    print(m)

24_6:

Задание выполняется с использованием прилагаемых файлов

 
В текстовом файле (по ссылке выше) находится цепочка из символов латинского алфавита A, B, C, D, E.
Найдите количество цепочек длины 3, удовлетворяющих следующим условиям:

  • 1-й символ – один из символов B, C или D;
  • 2-й символ – один из символов B, D, E, который не совпадает с первым;
  • 3-й символ – один из символов B, C, E, который не совпадает со вторым.
  • Ответ: 1280

    ✍ Решение:

      PascalABC.net:

      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
      15
      16
      
      begin
        assign(input, 'k7c-1.txt');
        var s: string;
        read(s); // весь текст файла
        var k := 0;
        var c1 := 'BCD';
        var c2 := 'BDE';
        var c3 := 'BCE';
        for var i := 1 to length(s) - 2 do
        begin
          if (s[i] in c1) and (s[i + 1] in c2) and (s[i + 2] in c3)
          and (s[i] <> s[i + 1]) and (s[i + 1] <> s[i + 2]) then
            k += 1
        end;
        print(k)
      end.

      Python:

      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      
      with open("k7c-1.txt") as Fin:
        s = Fin.readline()
       
      k = 0
      c1 = 'BCD'# строка проверки первого символа
      c2 = 'BDE'# строка проверки второго символа
      c3 = 'BCE'# строка проверки третьего символа
      for i in range(len(s)-2):
          if s[i] in c1 and s[i+1] in c2 and s[i+2] in c3 
             and s[i]!=s[i+1] and s[i+1]!=s[i+2]: # проверка повтора символов
            k += 1
      print(k)


    24_7:

    Задание выполняется с использованием прилагаемых файлов

     
    В текстовом файле (по ссылке выше) находится цепочка из символов, в которую могут входить заглавные буквы латинского алфавита A…Z и десятичные цифры. Найдите длину самой длинной подцепочки, состоящей из одинаковых символов. Если в файле несколько цепочек одинаковой длины, нужно взять первую из них. Выведите сначала символ, из которого строится эта подцепочка, а затем через пробел – длину этой подцепочки.

    Ответ: 2 3

    ✍ Решение:

      PascalABC.net:

      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
      15
      16
      17
      18
      19
      20
      21
      22
      23
      
      begin
        assign(input, 'D:/k8-0.txt');
        var s: string;
        read(s); // весь текст файла
        var k := 1; //длина текущей цепочки одинаковых символов 
        var max := 0; // макс длина цепочки одинаковых символов
        var c := s[1]; //символ, из которого строится самая длинная подцепочка
        for var i := 1 to length(s) - 1 do
        begin
          if s[i] = s[i + 1] then
          begin
            k += 1;
            if k > max then  
            begin
              max := k;
              c := s[i]; // запомнили новый символ
            end
          end
          else
            k := 1;
        end;
        print(c, max)
      end.

      Python:

      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
      
      f=open('k8-0.txt')
      s=f.readline()
      k=1
      m=0
      for i in range (1,len(s)):
          if s[i]==s[i-1] :
              k+=1
              if k>m:
                  m=k
                  symb=s[i]
          else:
              k=1
       
      print(symb,m)

    📹 Видеоразбор:
    📹 YouTube здесь

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


    24_8:

    Задание выполняется с использованием прилагаемых файлов

     
    Текстовый файл (по ссылке выше) содержит последовательность из строчных и заглавных букв английского алфавита и цифр, всего не более 106 символов. Определите длину наибольшей убывающей подпоследовательности.

    🎦 Видеоразбор

    Ответ: 3

    ✍ Решение:

      Общая идея:

    • В цикле сравнивается текущий элемент с предыдущим (цикл начинается со второго символа строки и заканчивается длиной строки).
    •  for var i := 2 to length(s) do
        begin
          if s[i] < s[i - 1] then
    • Если текущий элемент меньше предыдущего, то последовательность убывает, — увеличиваем счетчик длины последовательности.
    • Начальное значение счетчика длины последовательности должно быть = 1, так как в цикле сравниваются два элемента, и при истинности условия в последовательность уже должна быть равна двум, а не единице (в случае если счетчик обнуляется).
    • Увеличивая счетчик, сразу же необходимо сравнивать его значение с максимумом, и выполнять переприсваивание максимума, если это требуется.
    •  ...
           if k > max then  
                max := k;
    • В случае, если условие убывающей последовательности ложно, переходим в блок Иначе (else) и сбрасываем счетчик для работы со следующей последовательностью. Счетчик присваиваем единице!
    • После цикла выводим максимальное значение.
    • PascalABC.net:

      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
      15
      16
      17
      18
      19
      
      begin
        assign(input, 'D:/24.txt');
        var s: string;
        read(s); // весь текст файла
        var k := 1; //длина текущей бывающей последовательности символов 
        var max := 0; // макс длина
        for var i := 2 to length(s) do
        begin
          if s[i] < s[i - 1] then
          begin
            k += 1; // увеличиваем счетчик длины последовательности
            if k > max then  
              max := k;
          end
          else
            k := 1; // сбрасываем счетчик для работы со след. последовательностью
        end;
        print(max)
      end.

      Python:

      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      
      F= open("24.txt") 
      s = F.readline() # считали строку (весь текст файла в одной строке)
      k = 1
      maxim = 0
      for i in range(1, len(s)):
            if s[i] < s[i - 1]:
                k += 1 # увеличиваем счетчик длины последовательности
                if k > maxim:
                    maxim = k
            else:
                k = 1 # сбрасываем счетчик для работы со след. последовательностью
      print(maxim)

    Работа с числами (цифрами) в текстовом файле

    24_8:

    Задание выполняется с использованием прилагаемых файлов

     
    Текстовый файл (по ссылке выше) состоит не более чем из 106 символов. Определите максимальное нечётное число, записанное в этом файле.

    🎦 Видеоразбор

    Ответ: 7642289

    ✍ Решение:

      PascalABC.net:

      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
      15
      16
      17
      18
      19
      20
      21
      22
      23
      24
      25
      26
      27
      28
      29
      30
      31
      
      begin
        assign(input, '24-1.txt');
        var s: string;
        var b:integer;
        read(s); // весь текст файла находится в s
        var max := 0; // для максимального нечётного числа
        var num:integer;
        var strnum:string; // накапливает строковое представление числа
        strnum:='';
        for var i := 1 to length(s)-1 do
        begin
          if s[i].IsDigit() then // проверяем очередной символ - цифра ли это
            strnum += s[i] //добавляем очередную цифру в число
          else 
            if (strnum <> '') then //если встретилась не цифра, а strnum не пустая строка
              begin
              Val(strnum, num, b); // переводим в число
              if (num mod 2 <> 0) and (num > max) then // условие для поиска макс четного
                max := num;
              strnum:='';  // сбрасываем на начальное значение, чтобы накапливать новое число
              end;
        end;
        // проверка на случай, если самое большое нечётное в самом конце строки
        if (s[length(s)].isdigit()) then
          begin
          Val(strnum, num, b);
          if (num mod 2 <> 0) and (num > max) then
             max:= num;
          end;
      print(max)
      end.

      Python:

      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      14
      15
      16
      17
      18
      19
      
      F = open("24-1.txt")
      s = F.readline() # считали строку
       
      strnum = ''   #пустая строка,  strnum накапливает строковое представление числа
      maxim = 0            # для максимального нечётного числа
      for sym in s:
            if sym.isdigit(): # проверяем очередной символ - цифра ли это
                strnum += sym # добавляем очередную цифру в число
            elif strnum: # если встретилась не цифра, а strnum не пустая строка
                num = int(strnum) # переводим в число и сохраняем в num
                if num % 2 and num > maxim: # условие для поиска макс четного
                    maxim = num
                strnum = '' # сбрасываем на начальное значение, чтобы накапливать новое число
        # проверка на случай, если самое большое нечётное в самом конце строки
      if s[-1].isdigit():
         num = int(strnum)
         if num % 2 and num > maxim:
            maxim = num
      print(maxim)

    Работа с отдельными строками файла

    24_9:

    Задание выполняется с использованием прилагаемых файлов

     
    Текстовый файл (по ссылке выше) состоит не более чем из 106 заглавных латинских букв (A..Z). Текст разбит на строки различной длины.
    Определите количество строк, в которых буква J встречается чаще, чем буква E.

    Ответ: 482

    ✍ Решение:

      Общая идея:

    • Так как текст разбит на строки, то используем бесконечный цикл для считывания каждой строки.
    • Если строка пустая (т.е. достигнут конец файла), используем досрочный выход из цикла (оператор break).
    • Для подсчета количества встреченных символов используем строковый метод count(), который возвращает количество найденных вхождений символа (или сочетания символов), заданного аргументом.
    • PascalABC.net:

      1
      2
      3
      4
      5
      6
      7
      8
      9
      10
      11
      12
      13
      
      begin
        assign(input, '24-s1.txt');
        var s: string;
        var k := 0;
        while true do // бесконечный цикл
        begin
          readln(s); // считываем очередную строку
          if s = '' then break; // если строка пустая (т.е. достигнут конец файла), выходим
          if s.Count(c -> c = 'J') > s.Count(c -> c = 'E') then
            k += 1;
        end;
        print(k)
      end.

      Python:

      1
      2
      3
      4
      5
      6
      7
      8
      
      f= open("24-s1.txt")
      k = 0 # счетчик строк 
      while True: # бесконечный цикл
          s = f.readline() # считываем очередную строку
          if not s: break # если строка пустая (т.е. достигнут конец файла), выходим
          if s.count("J") > s.count("E"):
              k +=1
      print(k)


    ОГЭ

    Освоение образовательных программ основного общего образования завершается обязательной государственной итоговой аттестацией (далее – ГИА 9) по русскому языку и математике.


    Нормативно-правовые документы

    Приказы и методические документы


    Демоверсии, спецификации, кодификаторы

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


    Для предметных комиссий субъектов РФ


    Открытый банк заданий ОГЭ

    Новая версия открытого банка заданий


    Форум ЕГЭ по информатике
    Онлайн-тесты: ЕГЭ по информатике
    Генератор вариантов ЕГЭ
    Telegram-канал

    Что это такое?

    Здесь представлены материалы для подготовки к ЕГЭ по информатике.
    В отличие от известной литературы, для большинства задач из демо-вариантов ЕГЭ
    сравниваются несколько способов решения,
    анализируются их достоинства и недостатки, возможные проблемы и
    «ловушки». Приведены рекомендации, позволяющие выбрать
    эффективные методы решения каждой конкретной задачи.

    Автор признателен
    О.А. Тузовой (г. Санкт-Петербург) за обсуждение
    этих материалов и конструктивную критику. Спасибо всем, кто присылал и
    присылает мне замечания, предложения, сообщения об опечатках и неточностях.

    Особая благодарность Н.Н. Паньгиной (г. Сосновый Бор) за
    взаимовыгодное сотрудничество и разностороннюю поддержку проекта.

    Поддержать проект финансово

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

    Тренажёр компьютерного ЕГЭ

    ЕГЭ по информатике в 2023 году будет проводиться в компьютерной форме.
    На этом сайте вы можете попробовать, как это будет выглядеть в
    тренажёре. Он является копией официального тренажёра,
    но позволяет загружать любой вариант из генератора. Кроме того, после завершения
    пробного экзамена вы узнаете, сколько баллов вы набрали бы на ЕГЭ, если бы
    отправили такие ответы. Попробуйте:

    Тренажёр компьютерного ЕГЭ

    Авторские семинары

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

    Робот-Blockly

    Робот-Blockly Робот-Blockly — это версия исполнителей Робот и Водолей,
    программы для которых составляются из готовых блоков, как в Scratch. Это избавляет учеников от
    синтаксических ошибок, которые неминуемо возникают при ручном наборе текстовой программы.
    Программа подходит для вводного курса алгоритмизации в 5-6 (и даже более старших) классах.
    У программы есть оффлайн-версия, которую можно использовать
    без доступа к Интернету. Вы можете создавать свои наборы задач, а
    не только использовать готовые.

    Коллеги тащат то, что не приколочено…

    • Мартынов Антон Иванович, председатель предметной комиссии по информатике Ульяновской области,
      опубликовал представленные здесь рекомендации по решению задач части C под своим именем в
      официальном аналитическом отчете (Ульяновск, 2009).

    Актуальные публикации

    • В.С. Попов.

      Новая задача ЕГЭ по информатике № 22: решение с помощью графа
      // Потенциал: Математика, Физика, Информатика, № 8, 2022.
      Новинка!
    • К.Ю. Поляков.

      Особенности решения задач 25 и 26 в компьютерном
      ЕГЭ по информатике. Материалы вебинара для учителей г. Сочи, 24.03.2021.
    • К.Ю. Поляков.

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

      Задачи на анализ логических выражений в ЕГЭ по информатике. //
      Информатика в школе, № 9, 2019, с. 29–35.
    • А.Н. Сидоров


      Задача 18 ЕГЭ по информатике: логическое выражение с делимостью.

    • Н.Л. Конина


      Задачи 18 с делимостью.

    • Н.И. Герасименко


      Задачи 18 с делителями в КИМ ЕГЭ по информатике.

    • К.Ю. Поляков


      Линейное (и нелинейное) программирование в задаче 18 ЕГЭ по информатике (презентация).

    • К.Ю. Поляков,


      Битовые операции в задаче 18 КИМ ЕГЭ по информатике. Часть 2.

    • К.Ю. Поляков,

      Множества и логика в задачах ЕГЭ //
      Информатика, № 10, 2015, с. 38-42.
    • Е.А. Мирончик.

      Алгебра предикатов и построение геометрических моделей на ЕГЭ по информатике //
      Информатика, № 3, 2019, с. 40-47.

    См. также полный список статей.

    Что еще посмотреть?

    • Тренажёр для подготовки к компьютерному ЕГЭ
    • Тесты для подготовки к ЕГЭ (для системы NetTest)
    • Онлайн-тесты для подготовки к ЕГЭ
    • Генератор тренировочных вариантов ЕГЭ
    • Программное обеспечение
    • Статьи, презентации
    • Видеоматериалы
    • Дополнительные материалы
    • Материалы прошлых лет (демо-варианты, анализ, разбор задач)
    • Вопросы и ответы
    • Отзывы

    Новости теперь и в
    Telegram-канал К. Полякова Telegram-канале

    9 марта 2023 г.
        Исправлено условие задаче 8.330.
        Исправлен ответ к задаче 14.403.

    5 марта 2023 г.
        Новые задачи для тренировки 8, 9.

    4 марта 2023 г.
        Новые задачи для тренировки 14.
        Новые задачи для тренировки 1-3, 7-9, 12-16, 19-25, 27 (А. Богданов).
        Новая задача для тренировки 8 (А. Малышев).
        Новая задача для тренировки 17 (Д. Статный).

    3 марта 2023 г.
        Новые задачи для тренировки 26.
        Новые задачи для тренировки 23 (Д. Муфаззалов).

    2 марта 2023 г.
        Новые задачи для тренировки 27.

    28 февраля 2023 г.
        Новая задача для тренировки 27 (А. Бойко).

    25 февраля 2023 г.
        Новые задачи для тренировки 17 (И. Митин).
        Новые задачи для тренировки 23, 24, 25.
        Новые задачи для тренировки 23 (М. Шагитов).
        Новая задача для тренировки 27 (А. Рогов).

    24 февраля 2023 г.
        Новые задачи для тренировки 25, 26 (А. Рогов).

    23 февраля 2023 г.
        Изменено условие и ответ к задаче 26.94.

    Приложение для ОС Android

    Багрепорты, замечания, предложения можно присылать на
    форум.

    Официальные материалы

    Тренажёры для подготовки к компьютерному ЕГЭ (КЕГЭ)

    Лицензионное соглашение

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

    Без письменного согласия автора ЗАПРЕЩАЕТСЯ:

    1. 1) публикация материалов в любой форме, в том числе размещение материалов на других Web-сайтах;
    2. 2) распространение неполных или измененных материалов;
    3. 3) включение материалов в сборники на любых носителях информации;
    4. 4) получение коммерческой выгоды от продажи или другого использования материалов.

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

    Скачать все сразу

    Пароль к архиву — kpolyakov.spb.ru

    Информация

    Системы счисления

    Логика

    Пользовательский курс

    Алгоритмизация и основы программирования

    Ответы и решения

    Понравилась статья? Поделить с друзьями:
  • 509923 решу егэ
  • 509888 решу егэ математика профиль
  • 509840 решу егэ
  • 509836 решу егэ математика
  • 509835 решу егэ