Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.76/21: Рейтинг темы: голосов - 21, средняя оценка - 4.76
8 / 5 / 3
Регистрация: 16.12.2019
Сообщений: 23

Вика и Катя решили создать собственный шифр

16.12.2019, 21:41. Показов 4397. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Узнав на уроке информатики про шифрование данных при помощи открытых ключей, Вика и Катя решили создать собственный шифр. У Кати есть открытый ключ — набор из N чисел a1, a2, ..., aN. Вика передаёт ей N текстовых строк. Расшифровка будет являться словом, составленным из букв переданных строк. Первая буква должна встречаться в первой строке a1 раз, вторая — во второй a2 раз, и так далее. Помогите Кате расшифровать слово.

Формат ввода
Программа получает на вход число N — количество строк, не превосходящее 100. Затем следует строка из N натуральных чисел — нужное количество букв в каждой строке. Дальше записаны N строк, состоящих из строчных и прописных латинских букв.

Формат вывода
Программа должна вывести одну строку — зашифрованное слово. Если это сделать невозможно или вариантов расшифровки больше одного, программа должна вывести NO.

Пример 1
Ввод Вывод
3
1 2 3
abcabctabc
aabbbcccc
qwerrrtyu
tar
Пример 2
Ввод Вывод
2
1 3
abcd
twitter
NO
Примечания
Строчные и прописные буквы считаются разными.

Вот мой код:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
number = int(input())
strings = []
strocka = ''
sum = 0
list1 = list()
countsymb = [int(x) for x in input().split()]
for _ in range(number):
    strings.append(input())
for i in range(len(countsymb)):
    sum += int(countsymb[i])
for i in range(len(strings)):
    sum1 = 0
    for j in range(len(strings[i])):
        if strings[i].count(strings[i][j]) == countsymb[i]:
            strocka += strings[i][j]
            sum1 += 1
        if sum1 > countsymb[i]:
            break
if len(strocka) != sum:
    quit(print('NO'))
else:
    print(strocka)
У меня не получается вывести верный ответ. Помогите пожалуйста
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.12.2019, 21:41
Ответы с готовыми решениями:

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

Вика и Катя выросли и теперь работают с шифрованием данных в серьёзной компании
Вика и Катя выросли и теперь работают с шифрованием данных в серьёзной компании. Вика посылает Кате зашифрованную информацию - натуральное...

Петя и Катя – брат и сестра. Петя – студент, а Катя – школьница. Петя помогает Кате по математике
это задача на работу с файлами Петя и Катя – брат и сестра. Петя – студент, а Катя – школьница. Петя помогает Кате по математике....

1
55 / 40 / 18
Регистрация: 16.12.2019
Сообщений: 149
17.12.2019, 12:35
Лучший ответ Сообщение было отмечено alexey123456789 как решение

Решение

Оформляйте код в соответствующие теги.
Один из вариантов решения:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
from collections import Counter
 
 
n = int(input())
key = tuple(map(int, input().split()))
 
result = []
for i in range(n):
    for v, j in Counter(input()).items():
        if key[i] == j:
            if len(result) == i:
                result.append(v)
            else:
                result.clear()
                break
    if len(result) != i + 1:
        break
 
print(''.join(result) if len(result) == n else 'NO')
Добавлено через 16 минут
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
17.12.2019, 12:35
Помогаю со студенческими работами здесь

Создать собственный видеохостинг
Покидайте материалов по разработке видеохостинга на Python. Интересуют такие вопросы как: 1. Какие требования к аппаратной части и ОС ...

Создать собственный исключение
-Создать собственный исключение(class). -Создать метод, который может возбуждать (throw) это исключение (throws) -Написать метод,...

Создать собственный архиватор
Доброго времени суток! С Ubuntu познакомился совсем недавно, знаний практически никаких нет. Дали задание: сделать свой собственный...

Создать собственный Message
Добрый вечер. Прошу Вас подсказать в одном вопросе. Пытаюсь сделать собственное сообщение, которое определяет выход из приложения. Подобная...

Создать собственный тип
2. Создать собственный тип – запись, полями которого являются следующие данные: · фамилия; · предмет; · оценка (число из...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru