力扣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个斐波那契数。

总结

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

相关推荐
-dzk-2 小时前
【代码随想录】LC 59.螺旋矩阵 II
c++·线性代数·算法·矩阵·模拟
风筝在晴天搁浅2 小时前
hot100 78.子集
java·算法
Jasmine_llq2 小时前
《P4587 [FJOI2016] 神秘数》
算法·倍增思想·稀疏表(st 表)·前缀和数组(解决静态区间和查询·st表核心实现高效预处理和查询·预处理优化(提前计算所需信息·快速io提升大规模数据读写效率
超级大只老咪2 小时前
快速进制转换
笔记·算法
m0_706653232 小时前
C++编译期数组操作
开发语言·c++·算法
故事和你913 小时前
sdut-Java面向对象-06 继承和多态、抽象类和接口(函数题:10-18题)
java·开发语言·算法·面向对象·基础语法·继承和多态·抽象类和接口
qq_423233903 小时前
C++与Python混合编程实战
开发语言·c++·算法
TracyCoder1233 小时前
LeetCode Hot100(19/100)——206. 反转链表
算法·leetcode
m0_715575343 小时前
分布式任务调度系统
开发语言·c++·算法