极客时间-算法训练营 学习笔记 3递归的实现、特性以及思维要点

一 序

 本文属于极客时间-算法训练营 学习笔记

二 递归

递归本质就是循环,通过循环体调用自己来进行循环。


向下进入不同的递归层,向上又回到原来层。
用参数来进行函数不同层之间的传递变量。

递归模板:重要
递归终结条件
处理当前层逻辑
下探到下一层
清理当前层

public void recur(int level,int param){
        //递归终结条件
        if(level>MAX_LEVEL){
            return;
        }
        //处理当前层
        process(level,param);
 
        //下探到下一层
        recur(level:level+1,newParam);
 
        //清理当前层
        //reverse the current  level status if needed
    }

思维要点

  1. 不要人肉进行递归(最大误区,熟练后不要再画状态树,直接写函数本身)
  2. 找到最近最简方法,将其拆解成可重复解决的问题(重复子问题)
  3. 数学归纳法思维(简单条件成立的时候,从n->n+1)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值