Калужский Александр: Исправил!
05-09-2024
Читать статью
.: "Если число в двоичной форме имеет меньш..
Калужский Александр: Можно и так
02-09-2024
Сегодня посмотрим одно из самых интересных заданий из ЕГЭ по информатике 2025. Будем решать 24 задание. В этом задании нужно работать с файлами.
Все решения задач из задания 24 ЕГЭ по информатике 2025 будут приведены на языке программирования 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.
Закрепим это простое задание из ЕГЭ по информатике 2025.
Текстовый файл состоит не более чем из 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. Это не стопроцентная истина, но иметь ввиду это нужно.
Текстовый файл состоит не более чем из 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)
Если соседи различны, мы подсчитываем, иначе сбрасываем.
Текстовый файл состоит не более чем из 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'. Нечётной цифрой должна быть как текущая, так и следующая.
Решим ещё одну тренировочную задачу из ЕГЭ по информатике 2025.
Текстовый файл состоит не более чем из 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.
Текстовый файл состоит из символов 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 по этой же причине.
Мы проходим в цикле for до длины строки минус один. Значение 1 в счётчике при сбросе и в начале программы так же компенсирует и тот момент, что мы не подсчитываем последний символ!
При изменении счётчика, сохраняем максимальное значение в переменной mx
Если бы у нас была вместо PP другая комбинация, состоящая к примеру из 5 символов, то мы бы тогда в начале и при сбросе писали в счётчик значение 5-1=4.
Здесь тоже работает негласное правило, обращаемся к соседу, значит, счётчик устанавливаем в 1.
В этой задаче получается ответ 188.
Текстовый файл состоит из символов арабских цифр(0, 1, ...,9).
Определите максимальное количество идущих подряд символов в прилагаемом файле, среди которых нет трёх символов 0, стоящих рядом. Для выполнения этого задания следует написать программу.
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", к примеру.
Закрепите материал в видеоролике:
Текстовый файл состоит не более чем из 106 символов X, Y и Z. Определите максимальное количество идущих подряд символов, среди которых символ Z встречается не более одного раза.
В нашей цепочке один раз можно встретиь символ Z, а два раза уже нельзя. Здесь мы применим функцию .split(). Как работает эта фнкция? Напишем тестовую программу.
s='sadqttqtreq' a=s.split('q') print(a)
Результат данной программы будет следующим:
Команда 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]).
Каждого кандидата проверяем сразу на максимальность.
Текстовый файл состоит не более чем из 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)
Текстовый файл состоит не более чем из 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.
Текстовый файл состоит не более, чем из 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 не нужно.
Текстовый файл состоит из символов 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)
Текстовый файл содержит строку из символов 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.
Но чтобы проверить все варианты, мы должны запустить программу с 1-ого символа:
for i in range(1, len(s), 3):
Стандартная программа IDLE не выдаёт ошибку, когда мы берём последнюю тройку, но она оказывается не полной.
Так же нужно проверить и такой вариант:
for i in range(2, len(s), 3):
Среди трёх ответов выбираем наибольший 72.
Закрепите данную задача с помощью видеоролика:
Текстовый файл состоит не более чем из 106 символов X, Y и Z. Определите максимальную длину цепочки вида XYZXYZXYZ... (составленной из фрагментов XYZ, последний фрагмент может быть неполным). Для выполнения этого задания следует написать программу. Ниже приведён файл, который необходимо обработать с помощью данного алгоритма.
Т.к. последнее звено может быть неполным, здесь удобно применить другой алгоритм.
Пусть в начале показания счётчика равно нулю. Если мы находим нужный нам символ в нужной последовательности, то прибавляем к счётчику 1. Если последовательность сбивается, то ставим счётчик в ноль.
На рисунке представлен данный алгоритм. В нижней строке указано показание счётчика в момент анализа символа.
На данном рисунке максимальная длина цепочки нужных символов равна 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, иначе может произойти такая ошибка:
Т.е. первые три нужных символа в цепочке алгоритм не засчитал.
Поэтому мы не просто сбрасываем счётчик в ноль, а прописываем условие:
if s[i]=='X': k=1 else: k=0
Закрепите данную задачу с помощью видеоролика:
Текстовый файл 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). Вот часть этой таблицы.
Например, буква A кодируется кодом 65. Коды увеличиваются в алфавитном порядке на 1. Буква Z кодируется числом 90. Таким образом, 150 ячеек точно хватит для нашего алфавита. Здесь берём с запасом, потому что на экзамене можно точно не вспомнить коды, но достаточно запомнить, что 150 ячеек вполне хватит для заглавных и строчных букв латинского алфавита.
Значит, ячейка 65 отвечает за букву A, ячейка 66 отвечает за букву B и т.д. Если мы встретили букву между двумя одинаковыми буквами, то её ячейка увеличивается на 1.
Функция ord() превращает символ в код ANSI.
После того, как мы прошли всю строку и собрали информацию о наших буквах, нужно пройти массив a и найти наибольшее число в нём.
Здесь мы уже не пользуемся функцией max, а используем условие, потому что нужно кроме максимального числа тянуть ещё один параметр - сам код (переменную i). Функция chr() превращает код ANSI обратно в символ.
Закрепите данный приём с помощью видеоролика:
Текстовый файл 24-164.txt состоит не более чем из 106 символов и содержит только заглавные буквы латинского алфавита (ABC…Z). Текст разбит на строки различной длины. Необходимо найти строку, содержащую самую длинную цепочку стоящих подряд одинаковых букв. Если таких строк несколько, надо взять ту, которая в файле встретилась раньше. Определите, какая буква встречается в этой строке чаще всего. Если таких букв несколько, надо взять ту, которая стоит раньше в алфавите. Запишите в ответе эту букву, а затем – сколько раз она встречается во всем файле.
Пример. Исходный файл:
В этом примере в первой и второй строках наибольшая длина цепочек одинаковых буквы равна 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()
Далее будут примерные задачи с основной волны ЕГЭ по информатике 2023.
Текстовый файл состоит из символов A, B, C, D и E.
Определите в прилагаемом файле минимальное количество идущих подряд символов, среди которых символ A встречается 40 раз.
Для выполнения задания следует написать программу.
Рассмотрим пример. Пусть нужно подсчитать минимальное количество символов, где три буквы A.
s='ABBABBBABBABAB' a=s.split('A') print(a)
Мы разрезали с помощью команды split строку по символу "A" и распечатали куски, которые получатся в результате этого. Программа распечатает:
['', 'BB', 'BBB', 'BB', 'B', 'B']
На рисунке показаны цепочки-кандидаты:
Мы стараемся взять как можно меньше символов, но чтобы символов "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)
Здесь в начале длина первой цепочки-кандидата формируется до основного цикла. В цикле же левый кусок вычитается, а правый кусок прибавляется, таким образом, получается следующая цепочка-кандидат.
Как решать данную задачу методом двух указателей, читайте в статье. Смотрите разбор похожей задачи в видеоролике:
Определите в прилагаемом файле максимальное количество идущих подряд символов, среди которых символ A встречается не более 101 раз.
Рассмотрим пример из прошлой задачи. Пусть опять нужно найти максимальную цепочку, где не более трёх символов A.
Программа распечатает:
Здесь получаются 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)
Как решать данную задачу методом двух указателей, читайте в статье.
Текстовый файл состоит из символов, обозначающих знаки « – », « * » и цифры 0, 7, 8, 9.
Определите в прилагаемом файле максимальное количество идущих подряд символов, которые образуют математически правильную последовательность, в которую входят знаки « – » или « * » и натуральные числа без незначащих нулей.
f=open('24_2024_07.txt') s=f.read().strip() s=s.replace('-', '*') a=s.split('*') st='' kmax=0 for i in range(len(a)): if a[i]!='' and a[i][0]!='0': # Формируем цепочку-кандидата if st!='': st = st + '*' + a[i] else: st = st + a[i] if st.find('*')!=-1: kmax=max(kmax, len(st)) else: if a[i]!='' and a[i][0]=='0': a[i]=a[i].lstrip('0') st=a[i] else: st = '' print(kmax)
В начале заменяем знак "-" на умножение "*". В этой задаче нет разницы между "-" и "*", главное, что действие занимает один символ.
Разбиваем на отдельные кусочки строку s по символу "*" с помощью команды split().
Из кусочков начинаем формировать st (цепочку-кандидата под ответ). Нам не подходит пустой кусочек, он может получится, если два умножения стояли рядом "**". Так же не подходит кусочек, который начинается с нуля (об этом сказано в задаче). Если встретился один из этих вариантов, начинаем заново собирать строку st.
Но, если нас прервало какое-то число с незначащими нулями, например 007, то сама семёрка сгодится для начала новой цепочки. В этом случае удаляем с помощью lstrip() незначащие нули и присваиваем данный кусочек новой строке-кандидату st.
После изменения цепочки-кандидата проверяем её под ответ.
Обратите внимание, просто число ноль не подходит, т.к. в задаче сказано, что числа должны быть натуральными.
По условию задачи можно понять, что хотя бы один математический знак "*" или "-" должен быть в выражении. Мы это проверяем с помощью функции find().
Смотрите два видеоролика по данной задаче.
Обязательно посмотрите дополнение к этому ролику.
Текстовый файл состоит из десятичных цифр, знаков «+» и «*» (сложения и умножения). Определите максимальное количество символов в непрерывной последовательности, являющейся корректным арифметическим выражением с целыми неотрицательными числами (без знака), значение которого равно нулю. В этом выражении никакие два знака арифметических операций не стоят рядом, порядок действий определяется по правилам математики. В записи чисел отсутствуют незначащие (ведущие) нули.
В ответе укажите количество символов.
f=open('24_2024_19.txt') s=f.read().strip() # Функция проверяет ариф. выр. на ноль # В выражении может быть только * def F(s): if s!='' and ((s.find('*')!=-1 and (s.find('*0*')!=-1 or s[:2]=='0*' or s[-2:]=='*0')) or (s=='0')): return True else: return False s = s.replace('+*', '$').replace('**', '$').replace('++', '$').replace('*+', '$') kmax=0 a = s.split('$') for i in range(len(a)): b = a[i].strip('*+').split('+') st='' for j in range(len(b)): if F(b[j]): # Формируем цепочку-кандидата if st!='': st = st + '+' + b[j] else: st = st + b[j] kmax=max(kmax, len(st)) else: # К новой цепочке пытаемся добавить начало st = '' for k in range(1, len(b[j])+1): if F(b[j][-k:]): st = b[j][-k:] kmax=max(kmax, len(st)) print(kmax)
В данной задаче считается, что в файле нет чисел с незначащими нулями.
Разбиваем строку s по комбинациям, которые точно запрещены ('+*', '**', '++', '*+'). Каждую такую подстроку разбиваем по "+". Из получившихся кусочков формируем цепочку-кандидата. Функция F способна проанализировать: равно ли выражение нулю, если там присутствует только умножение.
Если выражение равно нулю, то добавляем его к строке-кандидату st. Если выражение не равно нулю, то попадаем в ветку else.
Это выражение, которое прервало цепочку, анализируем справа налево. Если находятся символы, которые в математическом смысле выдают ноль, то добавляем их в начало новой цепочки, которая только будет формироваться.
При изменении цепочки-кандидата, проверяем её под ответ.