力扣:剑指offer 斐波那契数列的两种解法(详解)
创始人
2024-06-02 04:57:29
0

前言:内容包括:题目,代码实现,大致思路

题目:

写一个函数,输入 n ,求斐波那契(Fibonacci)数列的第 n 项(即 F(N))。斐波那契数列的定义如下:

F(0) = 0,   F(1) = 1
F(N) = F(N - 1) + F(N - 2), 其中 N > 1.
斐波那契数列由 0 和 1 开始,之后的斐波那契数就是由之前的两数相加而得出。

答案需要取模 1e9+7(1000000007),如计算初始结果为:1000000008,请返回 1。

示例 1:

输入:n = 2
输出:1
示例 2:

输入:n = 5
输出:5
 

提示:

0 <= n <= 100

代码实现1:递归法

int fib(int n)
{int *f = (int*)malloc(sizeof(int)*101);f[0]=0;f[1]=1;int i = 0;
//得到从下标为2开始的任意一个斐波那契数值,需要得到除了已经确定好的0,1外的它前面的所有数值,这些要得到的数值,下标从2开始,至n结束for(i=2;i<=n;i++){f[i]=f[i-1]+f[i-2];f[i]%=1000000007;}return f[n];
}

大致思路:

斐波那契数列的第0项和第1项已经确定:0 1

1 malloc动态申请一块内存空间,用于存放斐波那契数列的数值

2 f[0] = 0 f[1] = 1

   n可以看作下标

   从下标为2开始的任意的一个斐波那契数值,等于它前两项斐波那契数列数值之和

代码实现2:非递归

int fib(int n)
{int a = 0;int b = 1;int c = 0;if (n == 1){return 1;}while (n >= 2){c = a + b;c %= 1000000007;a %= 1000000007;b %= 1000000007;a = b;b = c;n--;}return c;
}

大致思路:

斐波那契数列:

0 1 1 2 3 5……

 

1 第0项和第1项的数值是确定的,无需通过计算得到

当n>=2,即计算的是第2项及以后的斐波那契数值,则计算方法是:数值=前两项数值之和

2 以求第5个斐波那契数列为例:

   首先得到第2项:0+1=1 第一条蓝色线

   得到第3项: 1+1 = 2 第二条蓝色线

   得到第4项:1+2 = 3 第三条蓝色线

   得到第5项:2+3 = 5 第四条蓝色线

    总共需要计算四次,通项是:c=a+b,a=b,b=c,如此循环

   最终c就是结果

记得数值都要%1000000007

上一篇:vim 操作

下一篇:Canvas详细使用方法(二)

相关内容

热门资讯

122.(leaflet篇)l... 听老人家说:多看美女会长寿 地图之家总目录(订阅之前建议先查看该博客) 文章末尾处提供保证可运行...
育碧GDC2018程序化大世界... 1.传统手动绘制森林的问题 采用手动绘制的方法的话,每次迭代地形都要手动再绘制森林。这...
育碧GDC2018程序化大世界... 1.传统手动绘制森林的问题 采用手动绘制的方法的话,每次迭代地形都要手动再绘制森林。这...
Vue使用pdf-lib为文件... 之前也写过两篇预览pdf的,但是没有加水印,这是链接:Vu...
PyQt5数据库开发1 4.1... 文章目录 前言 步骤/方法 1 使用windows身份登录 2 启用混合登录模式 3 允许远程连接服...
Android studio ... 解决 Android studio 出现“The emulator process for AVD ...
Linux基础命令大全(上) ♥️作者:小刘在C站 ♥️个人主页:小刘主页 ♥️每天分享云计算网络运维...
再谈解决“因为文件包含病毒或潜... 前面出了一篇博文专门来解决“因为文件包含病毒或潜在的垃圾软件”的问题,其中第二种方法有...
南京邮电大学通达学院2023c... 题目展示 一.问题描述 实验题目1 定义一个学生类,其中包括如下内容: (1)私有数据成员 ①年龄 ...
PageObject 六大原则 PageObject六大原则: 1.封装服务的方法 2.不要暴露页面的细节 3.通过r...
【Linux网络编程】01:S... Socket多进程 OVERVIEWSocket多进程1.Server2.Client3.bug&...
数据结构刷题(二十五):122... 1.122. 买卖股票的最佳时机 II思路:贪心。把利润分解为每天为单位的维度,然后收...
浏览器事件循环 事件循环 浏览器的进程模型 何为进程? 程序运行需要有它自己专属的内存空间࿰...
8个免费图片/照片压缩工具帮您... 继续查看一些最好的图像压缩工具,以提升用户体验和存储空间以及网站使用支持。 无数图像压...
计算机二级Python备考(2... 目录  一、选择题 1.在Python语言中: 2.知识点 二、基本操作题 1. j...
端电压 相电压 线电压 记得刚接触矢量控制的时候,拿到板子,就赶紧去测各种波形,结...
如何使用Python检测和识别... 车牌检测与识别技术用途广泛,可以用于道路系统、无票停车场、车辆门禁等。这项技术结合了计...
带环链表详解 目录 一、什么是环形链表 二、判断是否为环形链表 2.1 具体题目 2.2 具体思路 2.3 思路的...
【C语言进阶:刨根究底字符串函... 本节重点内容: 深入理解strcpy函数的使用学会strcpy函数的模拟实现⚡strc...
Django web开发(一)... 文章目录前端开发1.快速开发网站2.标签2.1 编码2.2 title2.3 标题2.4 div和s...