| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 712 人关注过本帖
标题:关于递归的问题
只看楼主 加入收藏
wmy1
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2013-3-10
收藏
 问题点数:0 回复次数:2 
关于递归的问题
采用递归和非递归方法计算k阶裴波那契序列的第n项的值,序列定义如下:
f0=0, f1=0, …, fk-2=0, fk-1=1,
fn= fn-1+fn-2+…+fn-k(n>=k)
要求:输入k(1<=k<=5)和n(0<=n<=30),输出fn。
这题我想过,不过因为递归不熟悉。并且k与n的关系不好确定,求高手解决问题。感激不尽!
2013-03-10 20:34
smallacmer
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2013-3-14
收藏
得分:0 
首先你得明白递归是为了解决什么问题的,什么时候用递归什么时候不用递归。例如递归常见的用处就是在分治算法中,解决治的过程,分治的思想就是把规模大的问题转化为小问题来解决,然后再根据小问题的解进而得出最终的解。

针对这一题我建议你不要用递归的解法,因为这一题子问题之间并不是相互独立的,比如说你求一次fn-1要用到fn-2,fn-3,fn-4等,,,你最好用非递归先把求的数保存到数组里,最后直接相加就行了,这里只用到一次for循环就可得出答案
2013-03-14 15:06
忧伤的小王子
Rank: 2
等 级:论坛游民
帖 子:26
专家分:43
注 册:2012-9-12
收藏
得分:0 
迭代就行了。每次保存后两项。

我是一只不愿早起的菜鸟,我怕被虫吃……唯愿有一天化小虾一条!
2013-03-14 21:28
快速回复:关于递归的问题
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016898 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved