| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 847 人关注过本帖
标题:关于程序执行效率问题。
只看楼主 加入收藏
棉雨
Rank: 5Rank: 5
等 级:职业侠客
帖 子:174
专家分:368
注 册:2011-4-22
结帖率:78.26%
收藏
已结贴  问题点数:5 回复次数:8 
关于程序执行效率问题。
我想问一下,这个程序怎么改才能让它执行的效率高一点?
#include<iostream>
using namespace std;
int f(int n)
{
    if(n==1||n==2)
    return 1;
    else
    return f(n-1)+f(n-2);
}
void main()
{
    int i=1,n;
    cin>>n;
loop:if(i<=n)
    {
        cout<<f(i)<<"   ";
        i++;
        
        if(i%4==0)
            cout<<endl;
        goto loop;
    }
}
搜索更多相关主题的帖子: return 
2011-05-30 23:14
zaixuexi
Rank: 12Rank: 12Rank: 12
来 自:上海
等 级:火箭侠
威 望:8
帖 子:858
专家分:3233
注 册:2010-12-1
收藏
得分:0 
童鞋,发C++板块吧

技术问题,请不要以短消息方式提问
2011-05-30 23:31
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:1 
循环要比递归好些。

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-05-30 23:34
lz1091914999
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:四川
等 级:贵宾
威 望:37
帖 子:2011
专家分:5959
注 册:2010-11-1
收藏
得分:1 

My life is brilliant
2011-05-31 09:22
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:1 
程序代码:
#include<iostream>
using namespace std;
int f(int n,int dep)
{
    for(int i = 0;i<dep;i++)
        printf(" ");
    printf("f(%d)\n",n);
    if(n==1||n==2)
    return 1;
    else
    return f(n-1,dep+1)+f(n-2,dep+1);
}
void main()
{
    int i=1,n;
    cin>>n;
    printf("%d\n",f(n,0));
} 
看一下你递归的深度  递归了这么多层 效率是在是太低了

                                         
===========深入<----------------->浅出============
2011-05-31 09:35
棉雨
Rank: 5Rank: 5
等 级:职业侠客
帖 子:174
专家分:368
注 册:2011-4-22
收藏
得分:0 
回复 5楼 laoyang103
我运行了这个程序,却是递归了很多层。用迭代应该会好点吧。
在遇到诸如此类的问题的时候,是不是迭代的效率会不递归的高很多。
2011-05-31 10:01
棉雨
Rank: 5Rank: 5
等 级:职业侠客
帖 子:174
专家分:368
注 册:2011-4-22
收藏
得分:0 
回复 4楼 lz1091914999
学习了。
2011-05-31 10:02
laoyang103
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:内蒙古包头
等 级:贵宾
威 望:19
帖 子:3082
专家分:11056
注 册:2010-5-22
收藏
得分:1 
回复 6楼 棉雨
如果要递归也可以  保存中间值

                                         
===========深入<----------------->浅出============
2011-05-31 10:03
hellovfp
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:禁止访问
威 望:30
帖 子:2976
专家分:7697
注 册:2009-7-21
收藏
得分:1 
迭代和递归,有些应用环境用递归比较好,比如说搜索磁盘文件,注册表。
有时候,递归其实也可以用迭代来书写

[ 本帖最后由 hellovfp 于 2011-5-31 11:39 编辑 ]

我们都在路上。。。。。
2011-05-31 11:38
快速回复:关于程序执行效率问题。
数据加载中...
 
   



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

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