ho fatto riferimento a diverse domande qui circa la ricorsione, ma io non sono in grado di capire come la ricorsione funziona per questo particolare problema: programma ricorsivo per ottenere tutte le combinazioni di caratteri di una stringa in Python:La comprensione e la visualizzazione di ricorsione
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')
Ho fatto stampare i valori in modo che io possa vedere cosa sta succedendo. Questa è l'uscita:
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
uscita completa: http://pastebin.com/Lg3pLGtP
Come ho mostrato in uscita, come ha fatto diventare il prefisso 'ab'?
Ho provato a visualizzare le chiamate ricorsive per il combi (prefisso + s [0], s [1:]). Sto capendo bene?
ho pensato che il 2 ° chiamata ricorsiva cioè 'combi (prefisso, s [1:])' iniziare come 'combi ('', 'bc')' e seguire lo stesso processo formando b, bc. Qui all'ultimo passo s [0] c'è 'c' e quando ricorre il prefisso + s [0] diventa '' + c = c se capisco bene? A proposito, ho aggiunto un link di tipo passbin del risultato completo alla domanda. – Bharat
Se hai familiarità con la ricerca in profondità, è come viene menzionata l'albero che Amber sta attraversando (o generato, a seconda di come vuoi guardarlo). – kevintodisco
@ RBK: È la chiamata per 'combi ('a', 'c')' * da * 'combi ('a', 'bc')' che sta creando il secondo 'prefisso = 'a''. – Amber