|
网站首页
|
业界新闻
|
小组
|
威客
|
人才
|
下载频道
|
博客
|
代码贴
|
在线编程
|
编程论坛
|
登录
注册
短消息
我发表的主题
我参与的主题
我收藏的贴子
我上传的附件
我下过的附件
编辑个人资料
我的博客
用户控制面板
搜索
道具
恢复默认风格
碧海青天
秋意盎然
棕红预览
粉色回忆
蓝雅绿
紫色淡雅
青青河草
e点小镇
橘子红了
红红夜思
水晶紫色
雪花飘飘
新年快乐
风格
短消息
论坛展区
帮助
编程论坛
→
开发语言
→
『 数据结构与算法 』
→ 关于递归的问题
我的收件箱(0)
欢迎加入我们,一同切磋技术
用户名:
密 码:
共有
712
人关注过本帖
标题:
关于递归的问题
只看楼主
加入收藏
wmy1
等 级:
新手上路
帖 子: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
等 级:
新手上路
帖 子:1
专家分:0
注 册:2013-3-14
第
2
楼
收藏
得分:0
首先你得明白递归是为了解决什么问题的,什么时候用递归什么时候不用递归。例如递归常见的用处就是在分治算法中,解决治的过程,分治的思想就是把规模大的问题转化为小问题来解决,然后再根据小问题的解进而得出最终的解。
针对这一题我建议你不要用递归的解法,因为这一题子问题之间并不是相互独立的,比如说你求一次fn-1要用到fn-2,fn-3,fn-4等,,,你最好用非递归先把求的数保存到数组里,最后直接相加就行了,这里只用到一次for循环就可得出答案
2013-03-14 15:06
举报帖子
使用道具
赠送鲜花
忧伤的小王子
等 级:
论坛游民
帖 子:26
专家分:43
注 册:2012-9-12
第
3
楼
收藏
得分:0
迭代就行了。每次保存后两项。
我是一只不愿早起的菜鸟,我怕被虫吃……唯愿有一天化小虾一条!
2013-03-14 21:28
举报帖子
使用道具
赠送鲜花
3
1/1页
1
快速回复:
关于递归的问题
数据加载中...
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 0.058281 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved