玩蛇网提供最新Python编程技术信息以及Python资源下载!
您现在的位置: 玩蛇网首页 > Python问题解答 > 正文内容

python写一个递归函数

a = [1, 2, 3, 4]

如何才能生成

{'pid':1,'id':{'pid':2,'id':{'pid':3,'id':{...}}}

这样的结构呢

python3

>>> def f(ls):
    if len(ls)>1:
        x,*y=ls
    else:
        x,y=ls[0],None
    return {'pid':x,'id':f(y) if y else None}

>>> f([1, 2, 3, 4])
{'pid': 1, 'id': {'pid': 2, 'id': {'pid': 3, 'id': {'pid': 4, 'id': None}}}}
def fact(n):
    if n==1:
        return 1
    return n * fact(n - 1)

计算n的阶乘

python 2.7

 def gen(arr):
     if not arr:
         return None
     firstValue = arr[0]
     del arr[0]
     return {'pid': firstValue, 'id':gen(arr)}
 print(gen([1, 2, 3, 4]))
 

输出:

不过,题主呀,做伸手党是不好滴。。。

玩蛇网文章,转载请注明出处和文章网址:http://www.iplaypy.com/wenda/wd14238.html

相关文章 Recommend

玩蛇网Python互助QQ群,欢迎加入-->: 106381465 玩蛇网Python新手群
修订日期:2018年07月12日 - 14时42分54秒 发布自玩蛇网

我要分享到:

必知PYTHON教程 Must Know PYTHON Tutorials

必知PYTHON模块 Must Know PYTHON Modules