标题:这道题为什么会溢出呢
只看楼主
孤单旋律
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



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-334570-1-1.html




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

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