У меня есть список наций, и я хочу иметь самый длинный путь наций, где каждая страна выбрана должна начинаться с той же буквы, что положило конец предыдущего элементаНаибольшая цепь элементов из списка в 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']
Я пробовал этот путь, но он не работает
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
Любое предложение?
I n каким образом это не сработает? – Marcin
если я держу countrys.remove (j), ошибка ValueError: list.remove (x): x не в списке, если я удалю этот фрагмент кода RuntimeError: максимальная глубина рекурсии превышена при вызове объекта Python – fege
трассировки стека для обеих ошибок в вашем вопросе и использовать комментарий для определения строки используемого кода. – Marcin