day16 python学习 递归
初识递归
递归的定义——在一个函数里再调用这个函数本身
现在我们已经大概知道刚刚讲的story函数做了什么,就是在一个函数里再调用这个函数本身,这种魔性的使用函数的方式就叫做递归。
刚刚我们就已经写了一个最简单的递归函数。
递归的最大深度——997
正如你们刚刚看到的,递归函数如果不受到外力的阻止会一直执行下去。但是我们之前已经说过关于函数调用的问题,每一次函数调用都会产生一个属于它自己的名称空间,如果一直调用下去,就会造成名称空间占用太多内存的问题,于是python为了杜绝此类现象,强制的将递归层数控制在了997(只要997!你买不了吃亏,买不了上当...).
拿什么来证明这个“997理论”呢?这里我们可以做一个实验:
#初识递归
# def story():
# print('gushide neirongshi ')
# story()
# story()
#
#多大了alex,我不告诉你,alex比egon大两岁 44+2
#egon多大了,我不告诉你,egon比wusir大两岁 42+2
#wusir多大了,我不告诉你,wusir比金鑫大两岁 40+2
#金鑫40了
def age(n):
# if n==4:
# return 40
# return age(n+1)+2
# print(age(1))
# #以下是拆解的分析过程
# def age(4):
# if 4==4:
# return 40
# # return age(3+1)+2 n=4 这一步不执行
# def age(3):
# if 3==4: #3!=4这一步不执行
# return 40
# return age(3+1)+2 #根据age4的到age3的内容 age(3)=40+2=42
# def age(2):
# if 2==4: #2!=4这一步不执行
# return 40
# return age(2+1)+2#根据age3的到age2的内容 age(2)=42+2=44
# def age(1):
# if 1==4: #1!=4这一步不执行
# return 40
# return age(1+1)+2#根据age2的到age1的内容 age(1)=44+2
#最后也是开始调用了age(1)想得到到他得结果,print(age(1))
#
二分找法
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(l.index(66))#最传统的放法
#初级递归
# 但是1不能显示他的索引位,
#
# def func(l,n):
# mid=len(l)//2
# if l:
# if l[mid]>n:
# new_l=l[:mid]
# func(new_l,n)
# elif l[mid]<n:
# new_l=l[mid+1:]
# func(new_l,n)
# elif l[mid]==n:
# print(n,mid)
# else:
# print('数字不在内部')
# func(l,68)
二分找法
def func(l,n,start=0,end=None):#第一个问题,传参,这样传参数,就不会对函数进行切割,
if end==None:#而是去下标范围内的数值,l 不变
end=len(l)-1
if start < end: #当函数不存在时会出现func(l,n,mid+1,end)中的mid+1>end
mid=(start+end)//2# 因为取到所有的值了,此时end=0
if l[mid]>n:
func(l,n,start,mid)#这个是取的区间,而为改变列表
elif l[mid]<n:
func(l,n,mid+1,end)
elif l[mid]==n:
print(n,mid)
else:
print('数字不在内部')
func(l,67,start=0,end=None)
二分查找终极版
三级菜单
menu = {
'北京': {
'海淀': {
'五道口': {
'soho': {},
'网易': {},
'google': {}
},
'中关村': {
'爱奇艺': {},
'汽车之家': {},
'youku': {},
},
'上地': {
'百度': {},
},
},
'昌平': {
'沙河': {
'老男孩': {},
'北航': {},
},
'天通苑': {},
'回龙观': {},
},
'朝阳': {},
'东城': {},
},
'上海': {
'闵行': {
"人民广场": {
'炸鸡店': {}
}
},
'闸北': {
'火车战': {
'携程': {}
}
},
'浦东': {},
},
'山东': {},
}
def o_menu(menu):
while True:
for key in menu:
print(key)
select=input('选择')
if select=="q":
return 'q'
if select=='b':
return 'b'
if select in menu and menu[select]: 这句话的意思是满足select在menu中,而且 下一级为字典,不是空的情况
borq= o_menu(menu[select])#这儿跟send有点像,执行到这儿return o_menu(menu[select])
if borq=='q': #但是当能够执行下去的话,在下一次循环中我输入了b 就会把b return给
return 'q'#上一次调用的函数就是 o_menu(menu[select]) 然后就borq =="b"了什么也不做
o_menu(menu) #当等于'q"时,就会返回给上次的函数,直到跳出
三级菜单
day16 python学习 递归的更多相关文章
- python学习7—函数定义、参数、递归、作用域、匿名函数以及函数式编程
python学习7—函数定义.参数.递归.作用域.匿名函数以及函数式编程 1. 函数定义 def test(x) # discription y = 2 * x return y 返回一个值,则返回原 ...
- python学习三十五天函数递归的用法
python函数递归就是自己调用自己,无限循环,但是python限制了调用的次数1000次,就会终止,递归用在栏目分类,采集程序比较多,下面简单说函数递归用法和实例 1,函数递归用法 def func ...
- python学习之旅
python学习分类 python基础 +- day01——python初始.变量.常量.注释.基础数据类型.输入.if day02——while.字符串格式化.运算符.编码初识 day03—— ...
- Python 学习小结
python 学习小结 python 简明教程 1.python 文件 #!/etc/bin/python #coding=utf-8 2.main()函数 if __name__ == '__mai ...
- Python学习记录day6
title: Python学习记录day6 tags: python author: Chinge Yang date: 2016-12-03 --- Python学习记录day6 @(学习)[pyt ...
- Python学习记录day5
title: Python学习记录day5 tags: python author: Chinge Yang date: 2016-11-26 --- 1.多层装饰器 多层装饰器的原理是,装饰器装饰函 ...
- python学习心得第五章
python学习心得第五章 1.冒泡排序: 冒泡是一种基础的算法,通过这算法可以将一堆值进行有效的排列,可以是从大到小,可以从小到大,条件是任意给出的. 冒泡的原理: 将需要比较的数(n个)有序的两个 ...
- python学习笔记之module && package
个人总结: import module,module就是文件名,导入那个python文件 import package,package就是一个文件夹,导入的文件夹下有一个__init__.py的文件, ...
- python学习笔记(六)文件夹遍历,异常处理
python学习笔记(六) 文件夹遍历 1.递归遍历 import os allfile = [] def dirList(path): filelist = os.listdir(path) for ...
随机推荐
- bzoj2595: [Wc2008]游览计划 斯坦纳树
斯坦纳树是在一个图中选取某些特定点使其联通(可以选取额外的点),要求花费最小,最小生成树是斯坦纳树的一种特殊情况 我们用dp[i][j]来表示以i为根,和j状态是否和i联通,那么有 转移方程: dp[ ...
- UVA-701 The Archeologists' Dilemma (数论)
题目大意:给了一个2^E的前缀n,已知前缀n的位数不到2^E的位数的一半,找出满足条件的最小E. 题目解析:设2^E为i位数,则有n*10^i<2^E<(n+1)*10^i.解不等式得到i ...
- HDU-1548 A strange lift(单源最短路 或 BFS)
Problem Description There is a strange lift.The lift can stop can at every floor as you want, and th ...
- ORACLE常见方法使用(转)
1.DBMS_LOB包的使用 2.如何释放DBMS_LOB.CREATETEMPORARY的空间 3.oracle数组
- setuid和setgid
关于有效用户,实际用户的问题,参考: http://www.cnblogs.com/kunhu/p/3699883.html 内核对进程存取文件的许可检查,是通过考查进程的有效用户ID来实现的的. 在 ...
- Win10 dell驱动触摸板安装
Win10 dell驱动触摸板安装 在此之前安装驱动后要重启
- 转mysql半主从同步
MySQL半同步复制 从MySQL5.5开始,MySQL以插件的形式支持半同步复制.如何理解半同步呢?首先我们来看看异步,全同步的概念 异步复制(Asynchronous replication) ...
- POJ 2109 Power of Cryptography 大数,二分,泰勒定理 难度:2
import java.math.BigInteger; import java.util.Scanner; public class Main { static BigInteger p,l,r,d ...
- hdu 2874 Connections between cities(st&rmq LCA)
Connections between cities Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 32768/32768 K (J ...
- Django(四)模板文件中的循环
编辑views.py from django.shortcuts import render from django.shortcuts import HttpResponse #此行增加 # Cre ...