Ошибка.
Попробуйте повторить позже
Текстовый файл words.txt содержит только заглавные буквы латинского алфавита (ABC...Z). Текст разбит на строки различной длины. Необходимо найти строку, содержащую наибольшее количество пар соседних букв, которые стоят в таком же порядке как и в алфавите (например, AB, BC, CD и т.д.; в цепочке ABC две таких пары). Если таких строк несколько, надо взять ту, которая в файле встретилась раньше.
Выведите максимальное количество пар, встреченных среди всех строк, а также букву из данной строки, которая встречается чаще всего. Если таких букв несколько, вывести ту, что идет раньше по алфавиту.
Пример. Исходный файл:
ZCQABA
ZALMAC
CRACUT
В этом примере в первой и второй строках по одной подходящей паре (AB и LM), в третьей таких пар нет. Берём первую строку, т.к. она раньше встречается в файле. В этой строке чаще других встречается буква А. Если бы она была не единственной, то выбрали ту букву, что раньше стоит в алфавите. В ответе для этого примера надо записать 1A.
Решение 1
f = open(’words.txt’) s = [] while True: # считываем строку line = f.readline().replace(’\n’, ’’) # прерываем цикл, если строка пустая if not line: break s.append(line) maxim = 0 letter = ’’ for i in range(len(s)): count = 0 for j in range(len(s[i])-1): if ord(s[i][j]) == ord(s[i][j+1]) - 1: count += 1 if count > maxim: maxim = count t = sorted(s[i]) maxim_letter = 0 for k in t: if t.count(k) > maxim_letter: maxim_letter = t.count(k) letter = k print(maxim, letter, sep = ’’)
Решение 2
f = open(’words.txt’) n = 1000 ans = ’’ ma = 0 for i in range(n): count = 0 s = f.readline() s = s.strip() #чтобы убрать символ переноса строки for j in range(len(s) - 1): if ord(s[j]) + 1 == ord(s[j+1]): count += 1 if count > ma: ma = count ans = s alf = [0] * 26 for i in range(len(ans)): alf[ord(ans[i]) - 65] += 1 bukva = ’’ maxim = max(alf) for i in range(26): if alf[i] == maxim: bukva = chr(i + 65) break print(ma, bukva)
Специальные программы
Программа
лояльности v2.0
Приглашай друзей в Школково и получай вознаграждение до 10%!
Крути рулетку
и выигрывай призы!
Крути рулетку и покупай курсы со скидкой, которая привязывается к вашему аккаунту.
Бесплатное обучение
в Школково
Для детей ДНР, ЛНР, Херсонской, Запорожской, Белгородской, Брянской областей, а также школьникам, находящимся в пунктах временного размещения Крыма обучение на платформе бесплатное.
Налоговые вычеты
Узнай, как получить налоговый вычет при оплате обучения в «Школково».
Специальное предложение
для учителей
Бесплатный доступ к любому курсу подготовки к ЕГЭ или олимпиадам от «Школково». Мы с вами делаем общее и важное дело, а потому для нас очень значимо быть чем-то полезными для учителей по всей России!
Вернём деньги за курс
за твою сотку на ЕГЭ
Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!