Я упомянул несколько вопросов здесь о рекурсии, но я не могу понять, как рекурсия работает для этой конкретной проблемы: рекурсивной программы, чтобы получить все комбинации символов в строке в Python:Понимание и визуализация рекурсии
st= []
def combi(prefix, s):
if len(s)==0: return
else:
st.append(prefix+s[0])
''' printing values so that I can see what happens at each stage '''
print "s[0]=",s[0]
print "s[1:]=",s[1:]
print "prefix=",prefix
print "prefix+s[0]=",prefix+s[0]
print "st=",st
combi(prefix+s[0],s[1:])
combi(prefix,s[1:])
return st
print combi("",'abc')
Я сделал это для печати значений, чтобы я мог видеть, что происходит. Это выход:
s[0]= a
s[1:]= bc
prefix=
prefix+s[0]= a
st= ['a']
s[0]= b
s[1:]= c
prefix= a
prefix+s[0]= ab
st= ['a', 'ab']
s[0]= c
s[1:]=
prefix= ab
prefix+s[0]= abc
st= ['a', 'ab', 'abc']
s[0]= c
s[1:]=
prefix= a ----> How did prefix become 'a' here. Shouldn't it be 'abc' ?
prefix+s[0]= ac
st= ['a', 'ab', 'abc', 'ac']
.........
.........
['a', 'ab', 'abc', 'ac', 'b', 'bc', 'c'] # final output
Полный выход: http://pastebin.com/Lg3pLGtP
Как я показал на выходе, как же префикс стал «аб»?
Я попытался визуализировать рекурсивные вызовы для combi (префикс + s [0], s [1:]). Правильно ли я это понимаю?
Я думал, что 2-й рекурсивный вызов, т.е. 'комби (префикс, с [1:])' начнется как 'combi ('', 'bc')' и будет проходить тот же процесс, что и b, bc. Здесь на последнем шаге s [0] является 'c', и когда рекурсивный префикс + s [0] становится '' + c = c, если я его правильно понимаю? Кстати, я добавил ссылку на последний вывод на вопрос. – Bharat
Если вы знакомы с поиском глубин в начале, то, как упоминается дерево Янтарь, проходит (или генерируется, в зависимости от того, как вы хотите посмотреть на него). – kevintodisco
@RBK: Это вызов 'combi ('a', 'c')' * from * 'combi ('a', 'bc')', который создает второй 'prefix = 'a''. – Amber