python 之 函数 面向过程 三元表达式 函数递归

5.11 面向过程编程思想

核心是'过程'二字,过程即解决问题的步骤,即先干什么,再干什么........ 基于面向过程编写程序就好比在设计一条流水线,是一种机械式的思维方式。

总结优缺点: 优点:复杂的问题流程化,进而简单化 缺点:修改一个阶段,其他阶段都有可能需要做出修改,牵一发而动全身,即扩展性极差 应用:用于扩展性要求低的场景

5.12 三元表达式

三元表达式仅应用于: 1、条件成立返回 一个值 2、条件不成立返回 一个值

条件成立的情况下返回的值 if 条件 else 条件不成立的情况下返回的值
def max2(x,y):
   return x if x > y else y
print(max2(10,11))
def max2(x,y):
   if x > y:
       return x
   else:
       return y
res=max2(10,11)
print(res)

5.13 函数递归

递归分为两个阶段 1、回溯: 注意:一定要在满足某种条件结束回溯,否则的无限递归 2、递推

items=[1,[2,[3,[4,[5,[6,[7,[8,[9,[10,]]]]]]]]]]
def tell(l):
   for item in l:
       if type(item) is not list:
           print(item)
       else:
           tell(item)

tell(items)
def age(n):
   if n == 1:
       return 18
   return age(n-1)+2 #age(4)+2

age(5)

总结: 1、递归一定要有一个明确地结束条件 2、每进入下一次递归,问题的规模都应该减少 3、在python中没有尾递归优化

猜你喜欢

转载自www.cnblogs.com/mylu/p/11025631.html