1、递归

 递归的两个条件

 (1)、调用自身

 (2)、结束条件

看下面的几个函数:

递归、复杂度、列表查找、二分法

func1和func2都是错误的,func1没有结束条件,func2则是无穷的,func3和func4是正确的

2、时间复杂度

递归、复杂度、列表查找、二分法

递归、复杂度、列表查找、二分法

递归、复杂度、列表查找、二分法

 递归、复杂度、列表查找、二分法

递归、复杂度、列表查找、二分法

3、空间复杂度

递归、复杂度、列表查找、二分法

 4、列表查找

递归、复杂度、列表查找、二分法

递归、复杂度、列表查找、二分法

利用递归的方法进行二分法

data = [1, 3, 6, 7, 9, 12, 14, 16, 17, 18, 20, 21, 22, 23, 30, 32, 33, 35]

def binary_search(dataset,find_num):
    if len(dataset) > 1:
        mid = int(len(dataset) / 2)
        if dataset[mid] == find_num:  # find it
            print("找到数字", dataset[mid])
        elif dataset[mid] > find_num:  # 找的数在mid左面
            print("\033[31;1m找的数在mid[%s]左面\033[0m" % dataset[mid])
            return binary_search(dataset[0:mid], find_num)
        else:  # 找的数在mid右面
            print("\033[32;1m找的数在mid[%s]右面\033[0m" % dataset[mid])
            return binary_search(dataset[mid + 1:], find_num)
    else:
        if dataset[0] == find_num:  # find it
            print("找到数字啦", dataset[0])
        else:
            print("没的分了,要找的数字[%s]不在列表里" % find_num)

binary_search(data,20)

结果为:

递归、复杂度、列表查找、二分法

 

相关文章:

  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-02-21
  • 2021-10-08
猜你喜欢
  • 2021-12-19
  • 2021-05-27
  • 2021-06-01
  • 2022-02-01
  • 2021-11-30
  • 2021-11-10
  • 2022-01-02
相关资源
相似解决方案