关于递归的小技巧

本文探讨了递归的三个核心要素:明确函数目标、寻找递归结束条件和确定等价关系式。通过举例说明如何计算阶乘,强调递归结束条件的鲁棒性,以及如何通过缩小参数范围保持函数结果不变。此外,建议通过练习递归经典问题如反转链表和青蛙跳台阶来加深理解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

递归

递归的三大要素

  • 第一要素:明确函数想要干什么

    首先需要明确,这个函数的功能是什么,需要完成什么事情

    例如,计算n的阶乘,那么函数为

    // 算 n 的阶乘(假设n不为0)
    int f(int n){
        
    }
    
  • 第二要素:寻找递归结束的条件

    递归就是在函数内部的代码里面,调用自己的本身,那么需要有一个结束的条件,来结束无止境调用自己。

    参数为XXX时,递归结束,把结果返回,这个时候我们必须能根据这个参数的值,能够直接知道函数的结果是什么。

    例如计算n的阶乘,可以知道n=1时,结果为1,因此:

    // 算 n 的阶乘(假设n不为0)
    int f(int n){
        if(n == 1){
            return 1;
        }
    }
    

    注意,这个条件,需要考虑到鲁棒性,考虑为0等特殊情况。

  • 第三要素:找出函数的等价关系式

    我们要不断缩小参数的范围,缩小之后,我们可以通过一些辅助的变量或者操作,使原函数的结果不变。

    例如,f(n) 这个范围比较大,我们可以让 f(n) = n * f(n-1)。这样,范围就由 n 变成了 n-1 了,范围变小了,并且为了原函数f(n) 不变,我们需要让 f(n-1) 乘以 n。

    说白了,就是要找到原函数的一个等价关系式,f(n) 的等价关系式为 n * f(n-1),即

    f(n) = n * f(n-1)。

    // 算 n 的阶乘(假设n不为0)
    int f(int n){
        if(n <= 2){
            return n;
        }
        // 把 f(n) 的等价操作写进去
        return f(n-1) * n;
    }
    

其他:

  • 如果找不出规律,可以先将其带入尝试一遍。
  • 多尝试一些递归的经典题目:反转链表、青蛙台阶
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值