我正试图从这本字典中得到一个人的年龄级别:
d = {'Sıdıka': [{'Aziz': [{'Ahmet': [{'Kuzey': []}]}, {'Öznur': [{'Elif': []}, {'Yiğit': []}]}, {'İlknur': [{'Nurullah': []}, {'Büşra': []}]}, {'İlker': [{'Melih': []}]}]}]}
"Sıdıka"她是老大,我想确定她的等级是3 (Ex "Sıdıka")是"Kuzey"的吗爸爸的,爸爸的,妈妈的。
我怎么才能做到呢?
我尝试:递归,但不知道怎么回事。
我的尝试:
def new(self,dict,count,max):
for i in dict:
print(dict[i])
if len(dict[i])!=0:
for i in dict[i]:
self.new(self,i,count,max)
count+=1
print(count)
else:
return count
下面是一个简单的递归语句(假设d
是输入字典)
你可以取消注释,看看它是如何工作的。
def level(d, lvl=0):
#print(f'level {lvl}:', d)
return max((lvl, *(level(l, lvl=lvl+1)
for v in d.values()
for l in v)
))
level(d)
输出:3
我想我有办法了:
self.max_= 0
def new(self,dict,count):
for i in dict:
print(dict[i])
if len(dict[i])!=0:
for i in dict[i]:
print(self.max_)
self.new(self,i,count)
count+=1
# print(count)
else:
if count>self.max_:
self.max_=count
return self.max_