一、递归函数两大要素 -- 终止条件和递归方程
sum(n)=n+sum(n-1) #递归方程,以下为其展开 sum(n)=n+(n-1)+sum(n-2) ... sum(n)=n+(n-1)+(n-2)+...+sum(1)
到这里递归循环就应该结束了,很自然的我们得到了递归循环的结束条件:n=0,此时的返回就不是0+sum(-1)了,直接返回0结束循环即可。
从哪里开始和结束要分情况,在上例中有明确的结束条件n=0,n>0则进入递归循环,其隐形的条件就是n不能小于0,因此其开始条件写个n>0即可。
二、递归函数示例:
#!/usr/bin/env python def sum(list): sum = 0 # Add every number in the list. for i in range(0, len(list)): sum = sum + list[i] # Return the sum. return sum print(sum([5,7,3,8,10]))
#!/usr/bin/env python def sum(list): if len(list) == 1: return list[0] else: return list[0] + sum(list[1:]) print(sum([5,7,3,8,10]))
以上两个函数,第一个使用普通循环方式求和,第二个使用递归循环的方式求和,从效率来讲第一个更好,从逻辑上来讲递归函数更加清晰简洁。
#!/usr/bin/env python import sys sys.setrecursionlimit(5000) #阶乘实现示例: def factorial(n): if n == 1: return 1 else: return n * factorial(n-1) print factorial(3000)
四、递归函数的使用场景:
#coding=utf-8 from xml.dom.minidom import parse import sys reload(sys) sys.setdefaultencoding("utf-8") root=parse('<xml文件名>').documentElement #开始遍历节点 def iter_xmlNodes(node): if node == None: return if node.nodeType == node.ELEMENT_NODE: #只有ELEMENT_NODE类型的node才有遍历的必要 print ("ELEMENT Node:%s" %(node)) for child in node.childNodes: iter_xmlNodes(child) else: print ("Node:%s, NodeType:%d" %(node,node.nodeType)) #对于前两个if,第一个if表示终止条件,第二个if表示对输入节点的处理,对其子节点执行递归。 iter_xmlNodes(root)