| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2430 人关注过本帖
标题:输出Fibonacci数列中的前N项(从2开始输出的头3个数0 1 1 没有输出)
只看楼主 加入收藏
beyondyf
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:103
帖 子:3282
专家分:12654
注 册:2008-1-21
收藏
得分:0 
回复 19楼 wp231957
差不多吧,不过for循环的迭代部分最好理解成一句,因为这里的逗号不是分隔符,是运算符。

重剑无锋,大巧不工
2012-12-06 12:36
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
以下是引用beyondyf在2012-12-6 12:32:46的发言:

写成for(j = MAX_LEN; p[j] == 0; j--);会不会好理解一些?
这句代码貌似去寻找字符串的头,
但是把for(j--; !p[j]; j--);替换成for(j = MAX_LEN; p[j] == 0; j--);
得到的效果和删除这句代码的效果一样呢

DO IT YOURSELF !
2012-12-06 12:39
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
回复 22楼 wp231957
看错了,删除。。。

[ 本帖最后由 azzbcc 于 2012-12-6 12:45 编辑 ]


[fly]存在即是合理[/fly]
2012-12-06 12:43
beyondyf
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:103
帖 子:3282
专家分:12654
注 册:2008-1-21
收藏
得分:0 
回复 22楼 wp231957
纠正我的一处笔误,应该是for(j = MAX_LEN - 1; p[j] == 0; j--);

如果想看看这句删除的效果,还需要改一下f的尺寸,改成char f[MAX_N][MAX_LEN + 1] = {"1","1"};

重剑无锋,大巧不工
2012-12-06 13:03
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
看懂杨大哥的代码了

应该可以优化吧,加一个nowlength变量存储p的长度,这样那个找头的循环也不必写了,不知道对不对


[fly]存在即是合理[/fly]
2012-12-06 13:11
beyondyf
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:103
帖 子:3282
专家分:12654
注 册:2008-1-21
收藏
得分:0 
可以,只不过这个优化能节省的时间连一毫秒都不到,所以我懒得再增加三个变量使代码变复杂了。

重剑无锋,大巧不工
2012-12-06 13:16
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
汗颜!1毫秒,额,姑且贴出来吧!
程序代码:
for(i = 2; i < MAX_N; pt = p2, p2 = p1, p1 = p, p = pt, i++)
{
    for(t = j = 0; j < nowlength; t = p[j] > 9 ? p[j] -= 10, 1 : 0, j++)
        p[j] = p1[j] + p2[j] + t;
    if (p[nowlength] = t)    nowlength++;
    else    j--;
    for(t = 0; j >= 0; f[i][t++] = p[j--] + '0');
}


[fly]存在即是合理[/fly]
2012-12-06 13:22
快速回复:输出Fibonacci数列中的前N项(从2开始输出的头3个数0 1 1 没有输出)
数据加载中...
 
   



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

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