Тема 24. Программирование - Обработка символьной информации
24.03 Обработка символьной информации (Сложнее ЕГЭ)
Вспоминай формулы по каждой теме
Решай новые задачи каждый день
Вдумчиво разбирай решения
ШКОЛКОВО.
Готовиться с нами - ЛЕГКО!
Подтемы раздела программирование - обработка символьной информации
Решаем задачу:

Ошибка.
Попробуйте повторить позже

Задача 1#23396

Текстовый файл 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)

Ответ: 31C

Специальные программы

Все специальные программы

Программа
лояльности v2.0

Приглашай друзей в Школково и получай вознаграждение до 10%!

Крути рулетку
и выигрывай призы!

Крути рулетку и покупай курсы со скидкой, которая привязывается к вашему аккаунту.

Бесплатное обучение
в Школково

Для детей ДНР, ЛНР, Херсонской, Запорожской, Белгородской, Брянской областей, а также школьникам, находящимся в пунктах временного размещения Крыма обучение на платформе бесплатное.

Налоговые вычеты

Узнай, как получить налоговый вычет при оплате обучения в «Школково».

Специальное предложение
для учителей

Бесплатный доступ к любому курсу подготовки к ЕГЭ или олимпиадам от «Школково». Мы с вами делаем общее и важное дело, а потому для нас очень значимо быть чем-то полезными для учителей по всей России!

Вернём деньги за курс
за твою сотку на ЕГЭ

Сдать экзамен на сотку и получить обратно деньги за подготовку теперь вполне реально!

cyberpunkMouse
cyberpunkMouse
Рулетка
Вы можете получить скидку в рулетке!