码迷,mamicode.com
首页 > 其他好文 > 详细

day16 -- 递归函数,二分查找

时间:2018-06-22 17:41:31      阅读:122      评论:0      收藏:0      [点我收藏+]

标签:star   color   pac   ace   style   初始   简单   hit   递归函数   

一,递归函数

1,1初始递归

递归函数 :  在一个函数里调用这个函数本身

递归的最大深度 : 998

递归函数如果不受外力的阻止会一直执行下去,但是函数的每次调用都会产生一个属于自己的名称空间,如果一直调用下去的话,会出现名称空间过多导致的内存问题,所以为了避免这种现象,强制将递归层数控制在了997

def foo(n):
    print(n)
    n = n + 1
    foo(n)
foo(1

1,2 ,递归示例

问alex多大了,告诉你alex比egon大两岁,

然后去问egon多大了,egon说我比wusir大两岁,

然后又去问wusir,wusir说他比太白大两岁,

然后去问太白,太白说他18,这样就可以计算出alex到底多大了

age(4) = age(3) + 2
age(3) = age(2) + 2
age(2) = age(1) + 2
age(1) = 18

然后我们用函数表示

def age(n):
    if n == 1:
        return 18
    else:
        return age(n - 1) + 2
print(age(4))
#24

解析:

def age(4):
  if n == 1:
    return 26
  else:
    return age(3) + 2
def age(3):
  if n == 1:
    return 26
  else:
    return age(2) + 2
 
def age(2):
  if n == 1:
    return 26
  else:
    return age(1) + 2
def age(1):
  if n == 1:
    return 26
  else:
    return age(0) + 2
print(age(4))
age(4) = 26 + 2 + 2 + 2
 
 
二: 二分查找算法
是最经典最简单的算法
前提: 有序的,不重复的数字序列
l1 = [1, 2, 4, 5, 7, 9]
def two_search(l,aim,start=0,end=None):
    end = len(l)-1 if end is None else end
    mid_index = (end - start) // 2 + start
    if end >= start:
        if aim > l[mid_index]:
            return two_search(l,aim,start=mid_index+1,end=end)

        elif aim < l[mid_index]:
            return two_search(l,aim,start=start,end=mid_index-1)

        elif aim == l[mid_index]:
            return mid_index
        else:
            return 没有此值
    else:
        return 没有此值
print(two_search(l1,9))

 

 

day16 -- 递归函数,二分查找

标签:star   color   pac   ace   style   初始   简单   hit   递归函数   

原文地址:https://www.cnblogs.com/lianghui-lianghui/p/9214280.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!