首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >求数字列表中最小数的递归方法

求数字列表中最小数的递归方法
EN

Stack Overflow用户
提问于 2015-06-03 14:42:26
回答 6查看 7K关注 0票数 3

鉴于这份样本清单:

代码语言:javascript
复制
[5, 3, 9, 10, 8, 2, 7]

如何使用递归找到最小数目?答案是2

我在做递归练习的时候在一份试题中发现了这一点。我想不出解决这个问题的办法。要找到它,我必须先对列表进行排序,然后就没有什么可递归处理的了。有人能给我指明一条路吗?

EN

回答 6

Stack Overflow用户

回答已采纳

发布于 2015-06-03 14:59:00

这是min的递归实现。

代码语言:javascript
复制
l=[5, 3, 9, 10, 8, 2, 7]
def find_min(l,current_minimum = None):
    if not l:
        return current_minimum
    candidate=l.pop()
    if current_minimum==None or candidate<current_minimum:
        return find_min(l,candidate)
    return find_min(l,current_minimum)
print find_min(l)
>>>
2     

考虑到这一点不应在实际程序中使用,而应被视为一种练习。性能将比内置min差几个数量级。

票数 4
EN

Stack Overflow用户

发布于 2015-06-03 14:55:05

代码语言:javascript
复制
>>> import random
>>> arr=[random.randint(0,8) for r in xrange(10)]
>>> arr
[8, 2, 5, 1, 2, 4, 0, 3, 1, 1]
>>> def func(arr):
    if len(arr) == 1:
        return arr[0]
    else:
        return min(arr[0],func(arr[1:]))


>>> f(arr)
0

,NB,,这里并不真正需要递归。

票数 3
EN

Stack Overflow用户

发布于 2015-06-03 15:03:29

此答案使用累加器在递归过程中存储min值。

代码语言:javascript
复制
list = [5, 3, 9, 10, 8, 2, 7]

def min_list(list, min=None):
    if len(list) < 1:
        return min
    return min_list(list[1:], list[0] if min is None or list[0] < min else min)

print(min_list(list))
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/30623336

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档