• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

C语言数据结构递归之斐波那契数列

c语言 搞代码 4年前 (2022-01-06) 20次浏览 已收录 0个评论

这篇文章主要介绍了C语言数据结构递归之斐波那契数列的相关资料,希望通过本文能帮助到大家,让大家理解掌握这部分内容,需要的朋友可以参考下

C语言数据结构递归之斐波那契数列

因为自己对递归还是不太熟练,于是做POJ1753的时候就很吃力,就是翻棋子直到棋盘上所有棋子的颜色一样为止,求最少翻多少次,方法是枚举递归。然后就打算先做另一道递归的题(从数组中取出n个元素的组合),但是同样在递归的问题上不太理解。好吧,于是复习CPP,在第229页的时候,看到了斐波那契数列,回想起之前做过的一道题目,发现可以用递归的方法来做。于是决定优化一下之前的代码。

以下这段摘自《C primer plus》

斐波那契数列的定义如下:第一个和第二个数字都是1,而后续的每个数字是其前两个数字之和,例如,数列中前几个数字是1,1,2,3,5,8和13。…下面我们创建一个函数,它接受一个正整数n作为参数,返回相应的斐波那契数值。

首先,关于递归深度,递归提供了一个简单的定义。如果调用Fibonacci(),当n为1或2时Fibonacci(n)应返回1;对于其他数值应返回Fibonacci(n-1)+Fibonacci(n-2);

 long Fibonacci(n) { if (n > 2) return Fibonacci(n-1)+Fibonacci(n-2); else return 1; } 

然后是兔子总数问题。

有一对兔子,从出生后第三个月起每个月都生一对兔子,小兔子长到第三个月后又生一对兔子,假如兔子都不死,每个月兔子对数为多少?

思考这道题的时候,如果你简单的推算一下,会发现兔子每个月的对数就是斐波那契数列。

第一个月:1对;
第二个月:1对;
第三个月:2对;
第四个月:3对:
第五个月:5对:
第六个月:8对;
……

我之前做这道题的时候,觉得思路很简单,就是从第三个月起,求每个月的兔子数时,只要把这个月的前两个月总数相加。
这是我之前的代码,用f1和f2表示月。:

 #include int main() { int f1,f2; int month,ct; printf("请输入月份:"); scanf("%d",&month); if(month 2) { f1 = f2 = 1; ct = 0; while(ct <month -2){ f1=f1+f2; ct +=1; f2=f1+f2; 1; } if (month %2== 0){ printf("第 %d 个月的<strong style="color:transparent">来源gaodai#ma#com搞@@代~&码网</strong>兔子对数为:%d.\n",month,f2); 1){ 个月的兔子对数为:%d.\n",month,f1); return 0; <pre></div><p>其实这个代码离递归就差一步,很接近了。但是我当时完全没有想到。 <br /></p><p>这是我重新修改之后的代码:</p><div class="gaodaimacode"><pre class="prettyprint linenums"> #include long Fibonacci(n) { if (n > 2) return Fibonacci(n-1)+Fibonacci(n-2); else return 1; } int main() { long num; int month; printf("请输入月份:"); scanf("%d",&month); num = Fibonacci(month); printf("这个月的兔子对数为%d.\n",num); return 0; } 

只是很简单的修改,但是代码就整洁易懂了很多,也学到了新内容。

工欲善其事必先利其器,共勉。

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

以上就是C语言数据结构递归之斐波那契数列的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:C语言数据结构递归之斐波那契数列

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址