13.算法之递归案例

30 篇文章 0 订阅 ¥59.90 ¥99.00
目录介绍
  • 01.什么是递归
  • 02.递归三个条件
  • 03.斐波那契数列
  • 04.找指定目录下所有文件
  • 05.求1+2+…+N和
  • 06.求100的阶乘
  • 07.有序数组合并
  • 08.求一个数乘方
  • 09.背包问题
  • 10.选择一支队伍
  • 11.汉诺塔问题
  • 12.二分法查找
  • 13.警惕重复计算
  • 14.开源项目推荐

01.什么是递归

  • 递归:在一个方法内部对自身进行调用。利用递归可以用简单的程序来解决一些复杂的问题。比如:裴波那契数列的计算、汉诺塔、快排等问题。
  • 递归结构包括两个部分:
    • 1、定义递归头。解答:什么时候不调用自身方法。如果没有头,将陷入死循环,也就是递归的结束条件。
    • 2、递归体。解答:什么时候需要调用自身方法。

02.递归三个条件

  • 递归需要满足的三个条件。刚刚这个例子是非常典型的递归,那究竟什么样的问题可以用递归来解决呢?我总结了三个条件,只要同时满足以下三个条件,就可以用递归来解决。
  • 1.一个问题的解可以分解为几个子问题的解
    • 何为子问题?子问题就是数据规模更小的问题。比如,前面讲的电影院的例子,你要知道,“自己在哪一排”的问题,可以分解为“前一排的人在哪一排”这样一个子问题。
  • 2.这个问题与分解之后的子问题,除了数据规模不同,求解思路完全一样
    • 比如电影院那个例子,你
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值