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

posted @ 2019-06-14 21:53  small_white-  阅读(608)  评论(0编辑  收藏  举报