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中没有尾递归优化