Страницы

Поиск по вопросам

понедельник, 22 апреля 2019 г.

Как обозначить i+2 элемент массива

Помогите. Есть программа, которая расшифровывает нужный мне шифр по типу: А -- В (толко с инглишем) Г -- Е Буква вводится с клавиатуры и сравнивается с буквой в алфавите (который представлен в массиве) и, если введеная буква совпадает с 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, а также корректно обрабатывать заглавные.

Комментариев нет:

Отправить комментарий