Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.85/75: Рейтинг темы: голосов - 75, средняя оценка - 4.85
0 / 0 / 0
Регистрация: 12.10.2020
Сообщений: 13

Шифр подстановки

27.10.2020, 18:55. Показов 14805. Ответов 8

Студворк — интернет-сервис помощи студентам
Условие задачи:
Напишите программу, которая умеет шифровать и расшифровывать шифр подстановки. Программа принимает на вход две строки одинаковой длины, на первой строке записаны символы исходного алфавита, на второй строке — символы конечного алфавита, после чего идёт строка, которую нужно зашифровать переданным ключом, и ещё одна строка, которую нужно расшифровать.

Пусть, например, на вход программе передано:
abcd
*d%#
abacabadaba
#*%*d*%

Это значит, что символ a исходного сообщения заменяется на символ * в шифре, b заменяется на d, c — на % и d — на #.
Нужно зашифровать строку abacabadaba и расшифровать строку #*%*d*% с помощью этого шифра. Получаем следующие строки, которые и передаём на вывод программы:
*d*%*d*#*d*
dacabac

Мой код:
Python
1
2
3
4
5
6
7
8
9
10
11
a = input()
b = input()
str1 = input()
str2 = input()
 
for i in range(len(a)):
    str1 = str1.replace(a[i], b[i])
    str2 = str2.replace(b[i], a[i])
 
print(str1)
print(str2)
при пробных данных:
abcd
*d%#
abacabadaba
#*%*d*%
получается вывод:
*#*%*#*#*#*
dacabac
Хотя должно быть:
*d*%*d*#*d*
dacabac

Как будто 'b' читает как 'd', объясните что я не понимаю
Просьба не спойлерить какие-либо решения этой задачи
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.10.2020, 18:55
Ответы с готовыми решениями:

Шифр многоалфавитной одноконтурной обыкновенной подстановки
Есть вот такая вот программа, шифрующее предложение на русском языке, заменяя символы алфавита на символы трёх других алфавитов. Однако при...

Шифратор текста методом подстановки
Доброго времени суток! Помогите решить проблему. Мне нужно написать шифратор который, шифрует текст методом подстановки, т.е. есть таблица...

Принцип подстановки Барбары Лисков
Не понятен пример применения принципа ООП на python: Главная идея, стоящая за Liskov Substitution Principle в том, что для любого...

8
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
27.10.2020, 19:10
abc
bca
зашифровать: aabbcc

что ты делаешь:
1ое действие меняешь a на b, получается bbbbcc

дальше объяснять?
1
0 / 0 / 0
Регистрация: 12.10.2020
Сообщений: 13
27.10.2020, 19:12  [ТС]
Цитата Сообщение от eaa Посмотреть сообщение
дальше объяснять?
я нашел уже((((
пойду решать проблемы с невнимательностью
0
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5973 / 3735 / 1099
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
27.10.2020, 19:21
Тогда уж новые строки собирать

Python
1
2
3
m = {k: v for k, v in zip('abcd', '*d%#')}
print(*(m[i] for i in 'abacabadaba'), sep='')
# *d*%*d*#*d*
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
27.10.2020, 19:23
вам нужен ассоциативный массив (словарь)
0
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5973 / 3735 / 1099
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
27.10.2020, 19:23
В принципе словарь не так уж и нужен, но с ним будет быстрее.
0
0 / 0 / 0
Регистрация: 12.10.2020
Сообщений: 13
27.10.2020, 19:53  [ТС]
Цитата Сообщение от Рыжий Лис Посмотреть сообщение
Тогда уж новые строки собирать
примерно это и решил сделать
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
a = input()
b = input()
str1 = input()
str2 = input()
 
 
for i in range(len(str1)):
    for k in range(len(a)):
        if str1[i] == a[k]:
            print(b[k], end='')
print()
for i in range(len(str2)):
    for k in range(len(b)):
        if str2[i] == b[k]:
            print(a[k], end='')

ваше решение не совсем понятно, т к на курсе не было этих средств
0
Просто Лис
Эксперт Python
 Аватар для Рыжий Лис
5973 / 3735 / 1099
Регистрация: 17.05.2012
Сообщений: 10,791
Записей в блоге: 9
28.10.2020, 05:04
Лучший ответ Сообщение было отмечено kirillPoc как решение

Решение

Сойдёт.

zip позволяет итерироваться одновременно по нескольким итераторам раной длины

Python
1
2
3
4
5
6
7
>>> for k, v in zip('abcd', '*d%#'):
...     print(k, v)
... 
a *
b d
c %
d #
Ну и словарь, с которым не нужно писать второй цикл поиска.
Python
1
2
3
>>> d = {'a': '*', 'b': 'd', 'c': '%', 'd': '#'}
>>> d['a']
'*'
И итерируем строку:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
>>> for i in 'abacabadaba':
...     print(d[i])
... 
*
d
*
%
*
d
*
#
*
d
*
1
0 / 0 / 0
Регистрация: 12.10.2020
Сообщений: 13
28.10.2020, 14:53  [ТС]
Цитата Сообщение от Рыжий Лис Посмотреть сообщение
И итерируем строку:
Спасибо за помощь, словарь сначала пробовал, но не вышло из-за прошлых ошибок
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.10.2020, 14:53
Помогаю со студенческими работами здесь

Написать программу разложения произвольной подстановки в циклы
Доброго времени суток, нужно реализовать программу разложения произвольной подставки в циклы Даны подстановки: u = (1 2 3 4 5 6 7...

Напишите программу, которая умеет шифровать и расшифровывать шифр подстановки
Напишите программу, которая умеет шифровать и расшифровывать шифр подстановки. Программа принимает на входы две строки одинаковой...

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

Шифр, необычный шифр
Шифр показан на картинке, раньше таких не видел, решаю уже несколько часов

Шифровка методом подстановки степени n
помогите с алгоритмом, к примеру вводишь слово “Привет” и вводишь ключ размером равным длине вводимого слова, и по нажатию кнопки положение...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru