dewd

递归三要素
1). 明确递归终止条件

递归就是有去有回,因此必然应该有一个明确的临界点,程序一旦到达了这个临界点,就不用继续往下递去而是开始实实在在的归来,防止无限递归。

2). 在递归终止时提供处理办法

由于在递归函数中存在临界点,当满足临界点时,我们应该给出问题的解决方案。一般地,在这种情境下,问题的解决方案是直观的、容易的。

3). 提取重复的逻辑,缩小问题规模*

由于递归问题一定可以分解为若干个规模较小、操作流程相同的子问题,这些子问题可以用相同的解题思路来解决。从程序实现的角度而言,我们需要抽象出一个干净轻盈的逻辑,以便使用相同的方式解决子问题。

实例:
二分法查找:输入一个有序的元素列表(必须有序),如果要查找的元素包含在其中,二分法查找返回其位置,否则返回None。

def findNum(lst, a, b, num):
“”"
定义一个函数,使用二分法查找某元素在有序列表中的位置
:param lst: 有序列表
:param a: 列表的起始位置
:param b: 列表的结束位置
:param num: 要查找的元素
:return: 返回要查找的元素在有序列表中的位置
“”"
# 当要查找的元素在目标列表中时
if num in lst:
# 找出目标列表中间元素的下标
middle = int((a + b) / 2)
# 如果要查找的元素等于中间元素
if lst[middle] == num:
return ‘输入数字在列表中的索引是%d’ % middle
# 如果要查找的元素大于中间元素
elif lst[middle] < num:
return findNum(lst, middle, b, num)
# 如果要查找的元素小于中间元素
else:
return findNum(lst, 0, middle, num)
# 当要查找的元素不在目标列表中时
else:
return None

随机定义一个有序列表

lst1 = [1, 5, 8, 12, 26, 45, 86, 112, 258, 598, 698]

num1 = int(input(‘请列表中输入一个数字:’))

调用函数并输出

print(findNum(lst1,0,len(lst1),num1))

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值