вентилятор
Удачи на экзаменах!

ЕГЭ по информатике 2023 - Задание 24 (Полный разбор)



Сегодня посмотрим одно из самых интересных заданий из ЕГЭ по информатике 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().rstrip()
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", то подсчитываем, иначе сбрасываем. Функция rstrip() убирает символ "перенос строки" справа. По идее, его не должно быть в файле, но сделаем это на всякий случай.


Ответ: 34



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

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


Скачать файл


Решение:
f=open('24_2.txt')
s=f.read().rstrip()
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().rstrip()
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().rstrip()
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().rstrip()
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().rstrip()
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().rstrip()
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



Задача (Звенья перекрывают друг друга)

Текстовый файл содержит строку из символов A, B и С, всего не более чем 106 символов. Найдите максимальную длину строки, состоящей только из комбинаций BAC и CAB. Например, в строке BABABACCABCABCB такая подстрока BACCABCAB (длина 9).


Скачать файл


Решение:

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


Тогда нужно решать следующим образом:


f=open('24-224.txt')
s=f.read()
k=0
kmax=0
a=['BAC', 'CAB']

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

print(kmax)


При таком подходе мы будем брать по три символа s[i:i+3], и переменная i так же "прыгает" с шагом 3.


ЕГЭ по информатике задание 24 (Звенья пересекаются)

Но чтобы проверить все варианты, мы должны запустить программу с 1-ого символа:


for i in range(1, len(s), 3):

ЕГЭ по информатике задание 24 (Звенья пересекаются) 2

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


Так же нужно проверить и такой вариант:


for i in range(2, len(s), 3):

ЕГЭ по информатике задание 24 (Звенья пересекаются) 3

Среди трёх ответов выбираем наибольший 72.


Ответ: 72

Закрепите данную задача с помощью видеоролика:






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

Текстовый файл состоит не более чем из 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



Далее будут примерные задачи с основной волны ЕГЭ по информатике 2023.


Задача (ЕГЭ по информатике 2023, минимальная цепочка)

Текстовый файл состоит из символов A, B, C, D и E.

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

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


Скачать файл


Решение:

Рассмотрим пример. Пусть нужно подсчитать минимальное количество символов, где три буквы A.


s='ABBABBBABBABAB'
a=s.split('A')
print(a)

Мы разрезали с помощью команды split строку по символу "A" и распечатали куски, которые получатся в результате этого. Программа распечатает:


['', 'BB', 'BBB', 'BB', 'B', 'B']

На рисунке показаны цепочки-кандидаты:


ЕГЭ по информатике - задание 24 (реальный экзамен 2023)


Мы стараемся взять как можно меньше символов, но чтобы символов "A" было 3. Список a нумерует элементы начиная с 0. Поэтому первый кандидат будет состоять из 1-ого элемента и 2-ого. Второй кандидат будет состоять из 2-ого и 3-ого. А последний кандидат будет состоять из 3-ого и 4-ого.





Здесь нулевой элемент списка a и последний элемент не используются.


Напишем программу, которая будет перебирать цепочки-кандидаты так, как мы это обговорили выше, учитывая сами буквы "A".


s='ABBABBBABBABAB'
t=3
a=s.split('A')

for i in range(1, len(a)-t+1):
    st = '' # Цепочка-кандидат
    for j in range(i, i+t-1):
        st = st + 'A'
        st = st + a[j]
    st = st + 'A'
    print(st)

Получается:

ABBABBBA
ABBBABBA
ABBABA




Напишем код для нашей задачи.


f=open('24_2023_1.txt')

s=f.read().rstrip()

t=40

a=s.split('A')

k=0
kmin=10**10

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

    k=k+1
    kmin = min(kmin, k)

print(kmin)

При слишком большой входной строке программа может работать достаточно медленно из-за вложенных циклов. Исправим это:


f=open('24_2023_1.txt')

s=f.read().rstrip()

t=40

a=s.split('A')

k=0
kmin=10**10

for i in range(1, t):
    k=k+1
    k=k+len(a[i])

k=k+1
    
for i in range(t, len(a)-1):

    kmin = min(kmin, k)

    k=k-1
    k=k-len(a[i-t+1])
    k=k+len(a[i])
    k=k+1
    
kmin = min(kmin, k)

print(kmin)

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


Ответ: 81



Как решать данную задачу методом двух указателей, читайте в статье. Смотрите разбор похожей задачи в видеоролике:




Задача (ЕГЭ по информатике 2023, максимальная цепочка)

Текстовый файл состоит из символов A, B, C, D и E.

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

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


Скачать файл


Решение:

Рассмотрим пример из прошлой задачи. Пусть опять нужно найти максимальную цепочку, где не более трёх символов A.


s='ABBABBBABBABAB'
a=s.split('A')
print(a)

Программа распечатает:


['', 'BB', 'BBB', 'BB', 'B', 'B']

ЕГЭ по информатике - задание 24 (реальный экзамен 2023, максимальная цепочка)




Здесь получаются 3 цепочки кандидата. Мы хотим цепочки сделать как можно больше, но чтобы было символов A не более 3. В этой задаче и первый элемент списка a и последний элемент будут активно использоваться.


Напишем программу, которая распечатывает цепочки-кандиды.


s='ABBABBBABBABAB'
t=3

a=s.split('A')

for i in range(0, len(a)-t):
    st = ''
    for j in range(i, i+t+1):
        st = st + a[j]
        if j!=i+t:
            st = st + 'A'
    
    print(st)

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


ABBABBBABB
BBABBBABBAB
BBBABBABAB




В итоге получается решение:


f=open('24_2023_1.txt')

s=f.read().rstrip()

t=101

a=s.split('A')

k=0
kmax=0

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

print(kmax)

Первый цикл отвечает за количество цепочек-кандидатов. Второй цикл составляет цепочку-кандидата.





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


f=open('24_2023_1.txt')

s=f.read().rstrip()

t=101

a=s.split('A')

k=0
kmax=0

for j in range(0, t+1):
    k=k+len(a[j])
    if j!=t:
        k=k+1

for i in range(t+1, len(a)):

    kmax = max(kmax, k)

    k=k-len(a[i-t-1])
    k=k-1
    k=k+1
    k=k+len(a[i])
           
kmax = max(kmax, k)   

print(kmax)

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


Ответ: 584

Как решать данную задачу методом двух указателей, читайте в статье.







28-07-2022 в 08:05:47






Поддержать сайт:


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

ЕГЭ по информатике - Задание 22 (Опираемся на результаты предыдущих шагов)

Сегодня речь пойдёт о 22 задании из ЕГЭ по информатике....

Категория: Информатика  Подкатегория: ЕГЭ
Дата: 19-08-2020 в 18:31:17 0


Комментарии:

познавательно, спасибо!
влад 06-02-2023 в 16:02:15

В задаче 15 "Задача (Полезный приём)", созданы переменные k и kmax - напрасно, они не используются.
Александр Литвиненко 09-03-2023 в 10:52:41

Убрал, по привычке написал.
Калужский Александр 09-03-2023 в 11:02:35

Спасибо! Все разложили п полочкам, очень удобно!
Ильсеяр 27-04-2023 в 08:39:46

Спасибо, полезно, после этого решил убрать КУМИР из ПО для ЕГЭ!
Крылов 29-02-2024 в 12:59:27



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



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


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




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