六、 递归和迭代

一、 递归和迭代的区别

我在刚刷LeetCode的时候,在一道有关循环的题目的评论下面看到这样一句话,"迭代是人,递归是神"。

同时用递归方法解体很多时候确实不好想,所以当时我觉得递归非常NB,但是在经过一段时间的学习后,尤其是当开始考虑算法的效率的时候,我发现递归也是有很多缺点和限制的。

  1. 区别一:递归代码看起来简洁
  2. 区别二:递归的实现效率比不上循环
  3. 区别三:递归更容易出现栈溢出问题

二、斐波那契数列

2.1 递归方法解决

c++ 复制代码
class Solution {
public:
    int fib(int n) {
        if (n==0) return 0;
        else if (n==1) return 1;
        else return fib(n-1) + fib(n-2);
    }
};

代码看起来很简洁吧,但是如果n稍微大一点,代码直接报错

迭代方式解决

c++ 复制代码
class Solution {
public:
    int fib(int n) {
        if (n==0) return 0;
        else if (n==1) return 1;
        else {
            int MOD = 1000000007;
            int last_sum = 0;
            int p = 0, q = 0, r = 1;
            for(int i = 2; n>=i; i++){
                p = q;
                q = r;
                r = (p + q)%MOD;
            }
            return r;
        }
    }
};
相关推荐
Дерек的学习记录21 小时前
C++:入门基础(下)
开发语言·数据结构·c++·学习·算法·visualstudio
yugi98783821 小时前
无线传感器网络中GAF算法节点特性分析
网络·算法
1027lonikitave1 天前
使用斐波那契数列讲解尾递归
算法
滴滴答滴答答1 天前
LeetCode Hot100 之 16 合并两个有序链表
算法·leetcode·链表
ASKED_20191 天前
企业级大模型微调(Fine-tuning)策略
大数据·人工智能·算法
圣保罗的大教堂1 天前
leetcode 3713. 最长的平衡子串 I 中等
leetcode
t198751281 天前
基于Chirp分解和多相快速算法的离散分数傅里叶变换(DFRFT)MATLAB实现
开发语言·算法·matlab
愚者游世1 天前
力扣解决二进制 | 题型常用知识点梳理
c++·程序人生·算法·leetcode·职场和发展
阿星AI工作室1 天前
宝藏skills!90个顶尖博客信源自动抓,AI每天帮我筛出20篇精华!
人工智能·算法
Ulyanov1 天前
基于Python的单脉冲雷达导引头回波生成技术
python·算法·仿真·单脉冲雷达、