Рекурсивная комбинация клавиш не дает правильного результатаPython

Программы на Python
Ответить
Anonymous
 Рекурсивная комбинация клавиш не дает правильного результата

Сообщение Anonymous »

Я пытаюсь реализовать рекурсивную функцию для генерации комбинаций клавиш (например, клавиатуры старого мобильного телефона).

Код: Выделить всё

d = {
'1': "abc",
'2': "def",
'3': "ghi",
'4': "jkl",
'5': "mnop",
'6': "qrst",
'7': "uv",
'8': "wxyz",
'9': ".;",
'0': "?!"
}
Вот моя рекурсивная функция:

Код: Выделить всё

def keypad_combination(d , s , result , indx):
if indx == len(s):
return result

if len(result) == 0:
result = result.extend(d[s[indx]])
else:
for char in result:
char += d[s[indx]]

return keypad_combination(d,s,result, indx+1)

result = []
print(keypad_combination(d,"573",result,0))
При вызове вышеуказанной функции я получаю следующий результат:

Код: Выделить всё

% python ./questions.py
['m', 'n', 'o', 'p']
но желаемый результат — это все слова, которые могут быть образованы данным s.


Подробнее здесь: https://stackoverflow.com/questions/798 ... ect-result
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Python»