力扣509题:斐波那契数列的解法与代码注释

小学生一枚,自学信奥中,没参加培训机构,所以命名不规范、代码不优美是在所难免的,欢迎指正

代码是自己写的,文字是AI配的

斐波那契数列是一个经典的递归问题,通常用于理解动态规划和递归的基本概念。力扣第509题要求实现一个函数,计算第n个斐波那契数。以下是一个使用动态规划思想的C++解决方案,并附有详细注释。

代码实现

cpp 复制代码
class Solution {
public:
    int fib(int n) {
        // 定义一个数组来存储斐波那契数列的值
        int f[100];
        
        // 初始化前两个斐波那契数
        f[0] = 0;
        f[1] = 1;
        
        // 使用循环计算从第2个到第n个斐波那契数
        for(int i = 2; i <= n; i++) {
            f[i] = f[i - 1] + f[i - 2];
        }
        
        // 返回第n个斐波那契数
        return f[n];
    }
};

代码解析

  1. 数组定义 :代码中定义了一个大小为100的数组f,用于存储斐波那契数列的值。这个数组的大小可以根据实际需求进行调整,但需要确保能够存储到第n个斐波那契数。

  2. 初始化 :数组的前两个元素f[0]f[1]分别被初始化为0和1,这是斐波那契数列的起始值。

  3. 循环计算 :通过一个for循环,从第2个斐波那契数开始,依次计算每个斐波那契数,并将其存储在数组中。每个斐波那契数都是前两个数的和。

  4. 返回结果:最后,函数返回数组中的第n个元素,即第n个斐波那契数。

总结

通过动态规划的方法,可以高效地计算斐波那契数列。代码中的注释和优化建议有助于理解算法的实现细节,并为进一步优化提供了思路。

相关推荐
梁下轻语的秋缘8 分钟前
每日c/c++题 备战蓝桥杯(洛谷P1873 EKO砍树问题详解)
c语言·c++·蓝桥杯
永远向阳而生22 分钟前
【C++】vector容器实现
开发语言·c++
2401_859049081 小时前
Git使用
arm开发·git·stm32·单片机·mcu·算法
冠位观测者1 小时前
【Leetcode 每日一题】2942. 查找包含给定字符的单词
算法·leetcode·职场和发展
yi个名字2 小时前
C++继承:从生活实例谈面向对象的精髓
开发语言·c++·链表
蓝心湄2 小时前
C语言-枚举
c语言·开发语言·算法
轮到我狗叫了2 小时前
力扣小题, 力扣113.路径总和II力扣.111二叉树的最小深度 力扣.221最大正方形力扣5.最长回文子串更加优秀的算法:中心扩展算法
算法·leetcode·深度优先
黎明smaly2 小时前
【C语言】复习~动态内存管理
c语言·开发语言·c++·面试
黎明smaly2 小时前
【C语言】复习~数组和指针
c语言·开发语言·数据结构·c++·leetcode
haven-8522 小时前
最大似然估计(Maximum Likelihood Estimation, MLE)详解
算法·机器学习·概率论