重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
def Sum(m): #函数返回两个值:递归次数,所求的值 if m==1:return 1,m return 1+Sum(m-1)[0],m+Sum(m-1)[1]cishu=Sum(10)[0] print cishu def Sum(m,n=1): ... if m==1:return n,m ... return n,m+Sum(m-1,n+1)[1] print Sum(10)[0] 10 print Sum(5)[0] 5
创新互联建站2013年至今,先为化隆等服务建站,化隆等地企业,进行企业商务咨询服务。为化隆企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。
def factorial(n):
if n0:
return '负数不可以阶乘'
if n==1 or n==0:
return 1
return n*factorial(n-1)
print(factorial(10))
函数体里 调用 函数本身 就行
所谓基例就是不需要递归就能求解的,一般来说是问题的最小规模下的解。
例如:斐波那契数列递归,f(n) = f(n-1) + f(n-2),基例是1和2,f(1)和f(2)结果都是1
再比如:汉诺塔递归,基例就是1个盘子的情况,只需移动一次,无需递归
递归必须有基例,否则就是无法退出的递归,不能求解。