| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 375 人关注过本帖
标题:这道题为什么会溢出呢
只看楼主 加入收藏
孤单旋律
Rank: 2
等 级:论坛游民
帖 子:30
专家分:23
注 册:2010-10-22
结帖率:78.57%
收藏
已结贴  问题点数:12 回复次数:3 
这道题为什么会溢出呢
#include<stdio.h>
main(){
    __int64 n[100001];
    long i,j;
    n[1]=1;
    n[2]=2;

     for(i=3;i<100001;i++){
         if(n[i]%2==0)
            n[i]=n[i-2]+n[i/2];

         else{
            n[i]=n[i-1];
            n[i]=n[i]%100000000;

         }
     }
      scanf("%ld",&j);
      printf("%I64d\n",n[j]);
    return 0;
}

[ 本帖最后由 孤单旋律 于 2011-3-23 22:10 编辑 ]
搜索更多相关主题的帖子: long 
2011-03-23 22:05
qq1023569223
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:湖南科技大学
等 级:贵宾
威 望:26
帖 子:2753
专家分:13404
注 册:2010-12-22
收藏
得分:4 
数字太大了吧!

   唯实惟新 至诚致志
2011-03-23 22:40
禾才程
Rank: 2
等 级:论坛游民
帖 子:18
专家分:55
注 册:2010-12-11
收藏
得分:4 
同上,这个数后面跟着好多零啊,虽然理论上把他作为64位整形是可以的,数组下标也好大,这种for循环跟取模也不怎么可取,楼主不妨使用数组表示一个数,而且创函数递归也会好很多···
2011-03-23 22:53
j59342776
Rank: 1
来 自:江西乐平
等 级:新手上路
帖 子:1
专家分:4
注 册:2011-3-23
收藏
得分:4 
请问n[3]没赋初值你怎么可以用它。
2011-03-23 22:59
快速回复:这道题为什么会溢出呢
数据加载中...
 
   



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

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