十四. 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. Asp.net core 学习笔记 ( Web Api )

    asp.net core 把之前的 webapi 和 mvc 做了结合. mvc 既是 api. 但是后呢,又发现, api 确实有独到之处,所以又开了一些补助的方法. namespace Proje ...

  2. Python全栈开发-Day4-Python基础4

    本节内容 匿名函数 装饰器 列表生成式.迭代器&生成器 内置函数 Json & pickle 数据序列化 1. 匿名函数 匿名函数就是不需要显式的指定函数 1 2 3 4 5 6 7 ...

  3. Interval 间隔问题

    2018-09-07 09:03:14 一.Merge Intervals 问题描述: 问题求解: public List<Interval> merge(List<Interval ...

  4. legend2---开发日志6(后端和前端如何相互配合(比如php,js,元素状态和数据改变))

    legend2---开发日志6(后端和前端如何相互配合(比如php,js,元素状态和数据改变)) 一.总结 一句话总结:php给元素初始状态,js根据这个状态做初始化和后续变化,使用vue真的很方便( ...

  5. (4)进程---daemon守护线程和join阻塞

    join ()方法:主线程A中,创建了子线程B,并且在主线程A中调用了B.join(),那么,主线程A会在调用的地方等待,直到子线程B完成操作后,才可以接着往下执行,那么在调用这个线程时可以使用被调用 ...

  6. Mongodb 分享(一)

    Mongodb使用基础知识: 一.简介 1.mongodb是什么? 1)MongoDB 是一个基于分布式文件存储的数据库.由 )mongodb 客户端:NoSQL Manager for MongoD ...

  7. Windows 7 Update Settings Disabled (Important Updates Grayed Out)

    This worked for me: 1) Hold WindowsKey + R     (is hold Start & press R on your keyboard) 2) Typ ...

  8. 20165327 2017-2018-2 《Java程序设计》第8周学习总结

    20165327 2017-2018-2 <Java程序设计>第8周学习总结 教材内容总结 第十二章 (一)教材学习内容总结 线程是比进程更小的执行单位.一个进程在其执行过程中,可以产生多 ...

  9. MySql常用函数 --MySql

    1.目标 MySQL数据库中提供了很丰富的函数.MySQL函数包括数学函数.字符串函数.日期和时间函数.条件判断函数.系统信息函数.加密函数.格式化函数等.通过这些函数,可以简化用户的操作.例如,字符 ...

  10. java中的Sort函数,你值得看

    基于C语言中的sort如此这么方便,自然而然,java中也有类似C的sort函数. 1.普通数组:Arrays.sort(数组名,开始位置,结束位置). 2.类中属性排序: 模板: class A { ...