十四. Python基础(14)--递归

1 ● 递归(recursion)

概念: recursive functions—functions that call themselves either directly or indirectly in order to loop.

最大递归层数: the default maximum recursion depth in Python is 997.

限制条件: 一定有一个分支不调用自身

修改最大递归层数:

import sys

sys.setrecursionlimit(1500)

COUNT = 0

 

def func():

    global COUNT # 虽然函数内可以引用COUNT, 但是因为下面修改了COUNT, 所以要用global声明COUNT

    COUNT += 1

    print(COUNT)

    func()

 

func()

 

2 ● 递归的典型案例:

alex的年龄

阶乘

斐波那契数列

二分查找

三级菜单

 

3 ● alex的年龄

def age(n):

    if n == 4:

        return 40

    return age(n+1) + 2

 

print(age(4)) # 40

 

4 ● 阶乘

def fact(n):

    if n == 1:

        return 1

    return n * fact(n-1)

 

print(fact(4)) # 24

 

5 ● 斐波那契数列

def fib(n):

    if n ==1 or n == 2:

        return 1

    return fib(n-1) + fib(n-2)

 

print(fib(6)) # 8

 

6 ● 二分查找

def search(num, l, start = None, end =None):

    start = start if start else 0

    end = end if end else len(l)-1

    mid = (end-start)//2 + start

    if start > end:

        return None

    elif l[mid] > num:

        return search(num, l, start, mid - 1)

    elif l[mid] < num:

        return search(num, l, mid + 1, end)

    elif l[mid] == num:

        return mid

 

l = [2,3,5,10,15,16,18,22,26,30,32,35,41,42,43,55,56,66,67,69,72,76,82,83,88]

print(search(66,l)) # 17

 

7 ● 三级菜单

menu = {

    '北京': {

        '海淀': {

            '五道口': {

                'soho': {},

                '网易': {},

                'google': {}

            },

            '中关村': {

                '爱奇艺': {},

                '汽车之家': {},

                'youku': {},

            },

            '上地': {

                '百度': {},

            },

        },

        '昌平': {

            '沙河': {

                '老男孩': {},

                '北航': {},

            },

            '天通苑': {},

            '回龙观': {},

        },

        '朝阳': {},

        '东城': {},

    },

    '上海': {

        '闵行': {

            "人民广场": {

                '炸鸡店': {}

            }

        },

        '闸北': {

            '火车战': {

                '携程': {}

            }

        },

        '浦东': {},

    },

    '山东': {},

}

def Three_Level_Menu(menu):

    while True:

        for k in menu:print(k)

        key = input('>>>')

        if key == 'q':return 'q'

        elif key == 'b': # 退出本轮循环(递归函数造就了一个循环体)break

        elif key in menu:

            ret = Three_Level_Menu(menu[key])

            if ret == 'q':

                return 'q' # ① 回归到最后一层时, 没有key == 'q'为True的情况, 所以会return一个'q'(没有设置接受的变量), 然后结束整个函数; ② 如果ret !='q', 并且key不在当前字典的键里面, 那么重新开始本轮循环(递归函数造就了一个循环体)

Three_Level_Menu(menu)

另一方法:

pres_dic = menu # 当前词典

prev_dic = [] # 用来存储之前已经查询的词典

 

print("下面是可供查询的地点:")

while True:

    for key in pres_dic.keys():

        print(key)

    inp = input("请输入您要查询的地点, 输入b/B退回上一层, 输入q/Q退出查询:").strip()

    if inp not in pres_dic.keys() and inp.lower() != 'b' and inp.lower() != 'q':

        print("您输入的地点不存在, 请重新输入!")

        continue

 

    if inp in pres_dic.keys():

        prev_dic.append(pres_dic)

        pres_dic = pres_dic[inp] # 然后开始新一轮的循环

 

    if inp.lower() == 'b':

        if prev_dic != []: # 等价于if prev_dic:

            pres_dic = prev_dic[-1] # 当前词典编程
之前已经查询的词典列表
的最后一个

            del prev_dic[-1] # # 用来存储之前已经查询的词典列表去掉最后一个元素

        else:

            print("没有更大级别的地点了!")

 

    if inp.lower() == 'q':

        break

 

8 ● 面试真题

# 提取各个fields对应的数据

data={"time":"2016-08-05T13:13:05",

    "some_id":"ID1234",

    "grp1":{ "fld1":1,"fld2":2},

    "xxx2":{ "fld3":0,"fld5":0.4},

    "fld6":11,

    "fld7":{"fld100": 0, "fld500": 0.4},

    "fld46":8}

#fields:由"|"连接的以"fld"开头的字符串,如:fld2|fld3|fld7|fld19

# 解法1:

def select(data,fields):

    result = {}

    field_lst = fields.split('|')

    for key in data:

        if key in field_lst:

            result[key] = data[key]

        if type(data[key]) == dict:    # 不要写成elif, 否则, "fld100"对应的数据无法提取出来

            res = select(data[key],fields)

            result.update(res)

    return result

# 解法2:

def select(data,fields,result = {}):

    field_lst = fields.split('|')

    for key in data:

        if key in field_lst:

            result[key] = data[key]

        if type(data[key]) == dict: # 不要写成elif, 否则, "fld100"对应的数据无法提取出来

            select(data[key], fields)

    return result

 

fields = 'fld2|fld3|fld7|fld19|fld100'

ret = select(data,fields)

print(ret) # {'fld2': 2, 'fld3': 0, 'fld7': {'fld100': 0, 'fld500': 0.4}, 'fld100': 0}

 

 

十四. Python基础(14)--递归的更多相关文章

  1. 二十四. Python基础(24)--封装

    二十四. Python基础(24)--封装 ● 知识结构   ● 类属性和__slots__属性 class Student(object):     grade = 3 # 也可以写在__slots ...

  2. 十八. Python基础(18)常用模块

    十八. Python基础(18)常用模块 1 ● 常用模块及其用途 collections模块: 一些扩展的数据类型→Counter, deque, defaultdict, namedtuple, ...

  3. 二十六. Python基础(26)--类的内置特殊属性和方法

    二十六. Python基础(26)--类的内置特殊属性和方法 ● 知识框架 ● 类的内置方法/魔法方法案例1: 单例设计模式 # 类的魔法方法 # 案例1: 单例设计模式 class Teacher: ...

  4. 十六. Python基础(16)--内置函数-2

    十六. Python基础(16)--内置函数-2 1 ● 内置函数format() Convert a value to a "formatted" representation. ...

  5. 四. Python基础(4)--语法

    四. Python基础(4)--语法 1 ● 比较几种实现循环的代码 i = 1 sum = 0 while i <= 10: # 循环10-1+1=10次     sum += i     i ...

  6. 「kuangbin带你飞」专题十四 数论基础

    layout: post title: 「kuangbin带你飞」专题十四 数论基础 author: "luowentaoaa" catalog: true tags: mathj ...

  7. 二十五. Python基础(25)--模块和包

    二十五. Python基础(25)--模块和包 ● 知识框架   ● 模块的属性__name__ # my_module.py   def fun1():     print("Hello& ...

  8. 二十二. Python基础(22)--继承

    二十二. Python基础(22)--继承 ● 知识框架   ● 继承关系中self的指向 当一个对象调用一个方法时,这个方法的self形参会指向这个对象 class A:     def get(s ...

  9. 十九. Python基础(19)--异常

    十九. Python基础(19)--异常 1 ● 捕获异常 if VS异常处理: if是预防异常出现, 异常处理是处理异常出现 异常处理一般格式: try:     <............. ...

随机推荐

  1. 雷林鹏分享:jQuery EasyUI 扩展

    jQuery EasyUI 扩展 Portal(制作图表.列表.球形图等) 数据网格视图(DataGrid View) 可编辑的数据网格(Editable DataGrid) 可编辑的树(Editab ...

  2. English Voice of <<See You Again >>

    <See You Again >(<当我们再相见>) 演唱:Wiz Khalifa/Charlie Puth  维兹·卡利法/查理·普斯 It's been a long da ...

  3. Confluence 6 查看所有空间

    有下面 2 种方法在 Confluence 中查看空间: 空间目录(The space directory) – 在 Confluence 的头部选择 空间(Spaces )> 空间目录(Spa ...

  4. vue生命周期 钩子函数

    首先,1.x和2.x的生命周期钩子对比: 钩子函数的树状图,红色的是我们可以利用的函数,绿色的是函数解析,蓝色的是函数执行时机 <!DOCTYPE html> <html> & ...

  5. MySQL事务(三)

    一.事务(Innodb锁)的隔离级别概述 并发事务带来的问题: 更新丢失(lost update):当两个或多个事务选择同一行,然后基于最初选定的值更新该行时,由于每个事务都不知道其他事务的存在,就会 ...

  6. 【洛谷p2142】高精度减法

    高精度减法第一遍没有过 高精度减法[传送门] 洛谷算法标签: 总之技术都在高精上了吧. 附代码: #include<iostream> #include<cstdio> #in ...

  7. 微信公众号使用LocalStorage解决返回缓存问题

    在开发微信公众号上应用程序时,遇到了一个普遍的问题,从A页跳转到B页后,再由B页跳转回A页,A要要保持跟跳转前一致,通过LocalStorage可以解决. LocalStorage,很好的解决了返回的 ...

  8. Echarts 简单报表系列二:折线图

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. Linux下切换使用两个版本的JDK

    Linux下切换使用两个版本的JDK 我这里原来已经配置好过一个1.7版本的jdk. 输出命令: java -version [root@hu-hadoop1 sbin]# java -version ...

  10. const 内联 枚举 宏

    const 常量   程序运行时在常量表中,系统为它分配内存,在堆栈分配了空间:const常量有数据类型:语句末有分号:有类型检查:可以限制范围 //将所有不希望改变的变量加const修饰 const ...