m0_67278295 2022-06-28 12:31 采纳率: 100%
浏览 5
已结题

我这递归出口是不是写错了,总是返回None

def func(ls:list):
    if len(ls) == 1:
        return ls[0]
    else:
        func(ls[:len(ls) // 2])



#  预期返回列表中某个值,但是返回都是None
  • 写回答

1条回答 默认 最新

  • it_hao528 2022-06-28 14:02
    关注

    你这写的只有当ls的len为1时才返回第一个数据ls[0]
    当ls的len > 1时,只是调用了该方法,并没有将其值返回,如果将else的内容return的话,最终的返回结果还会是第一个元素ls[0]。
    你需要先理清楚需求到底是返回列表中的哪个值,不是所有的算法都需要用到递归的。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 7月6日
  • 已采纳回答 6月28日
  • 创建了问题 6月28日

悬赏问题

  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条
  • ¥15 关于#windows#的问题:怎么用WIN 11系统的电脑 克隆WIN NT3.51-4.0系统的硬盘