Помогите. Есть программа, которая расшифровывает нужный мне шифр по типу:
А -- В (толко с инглишем)
Г -- Е
Буква вводится с клавиатуры и сравнивается с буквой в алфавите (который представлен в массиве) и, если введеная буква совпадает с i- элементом, то в другой (пустой) массив добавляется буква, идущая через 1 от этот i в алфавите, то есть i+2.
Но у меня вылетает :
Can't convert 'int' object to str implicitly
Как правильно обозначить i+2 элемент?
http://ideone.com/Kcv64C
n = 1
while n:
x = (input('х : '))
exp = []
a = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l',
'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
for i in a:
if x == i:
ex = i + 2
exp.append(ex)
elif x == 'y':
exp.append('a')
if x == ' ':
exp.append(x)
elif x == '.':
exp.append(x)
print(exp)
Ответ
Это называется "шифр Цезаря".
Можно использовать функцию enumerate, чтобы знать текущую позицию в списке.
for i, char in enumerate(a):
if x == char:
exp.append(a[i + 2])
Чтобы не вываливалось IndexError в конец массива и не приходилось костыли приписывать, можно использовать типичный для таких случаев трюк с оператором %, чтобы индекс не выходил за предел:
for i, char in enumerate(a):
if x == char:
exp.append(a[(i + 2) % 26])
Если вы хотите проверить является символ буквой, то можно воспользоваться следующим методом, а не писать на каждый символ свое условие:
x.isalpha()
К слову: вам не обязательно пробегать по списку, ведь у букв есть известный порядок. Вы можете узнать номер буквы в таблице юникода с помощью функции ord() - прописные латинские начинаются с 97 позиции (a) и следуют до 122 (z). Затем прибавляем к номеру 2 и узнаем какая буква находится на этой позиции через функцию chr(). Только нужно опять быть аккуратным и не выскочить за границы 97-122, а также корректно обрабатывать заглавные.
Комментариев нет:
Отправить комментарий