ho una lista delle nazioni, e voglio avere il percorso più lungo delle nazioni in cui ogni paese scelto deve iniziare con la stessa lettera che si è conclusa l'elemento precedentepiù lunga catena di elementi di lista in Python
nations = ['albania','andorra','austria','belarus','belgium','bosnia and herzegovina',
'bulgaria','croatia','czech republic','denmark','estonia',
'finland','france','germany','greece','hungary',
'iceland','ireland','italy','latvia','liechtenstein','lithuania','luxembourg',
'macedonia','malta','moldova','monaco','montenegro','netherlands',
'norway','poland','portugal','romania','russia',
'san marino','serbia','slovakia','slovenia','spain','sweden', 'switzerland',
'ukraine','united kingdom','vatican city']
chain('spain')
>>>['spain', 'netherlands', 'slovenia', 'andorra', 'austria', 'albania']
Ho provato in questo modo, ma non funziona
def chain(naz):
initial = naz[-1]
initials=[]
res = set()
res.add(naz)
for i in nations:
if i.startswith(initial):
initials.append(i)
for j in initials:
nations.remove(j)
res.add(j)
chain(j)
return res
Qualche suggerimento?
I in che modo non funziona? – Marcin
se tengo nation.remove (j), l'errore è ValueError: list.remove (x): x non in lista, se rimuovo quel pezzo di codice RuntimeError: massima profondità di ricorsione superata mentre si chiama un oggetto Python – fege
Si prega di inserire pieno impila le tracce per entrambi gli errori nella tua domanda e usa un commento per identificare la linea di codice coinvolta. – Marcin