| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2979 人关注过本帖
标题:数组长度不够
只看楼主 加入收藏
zhangx378
Rank: 1
等 级:新手上路
帖 子:58
专家分:0
注 册:2016-9-29
结帖率:90.91%
收藏
 问题点数:0 回复次数:12 
数组长度不够
定义一个数列b[i], 从第三项开始,每一项等于前两项的乘积,现在给出第一和第二项以及整数n,请你算出第n项mod 10007的结果。
#include<stdio.h>  
#include<stdlib.h>
int main()
{
    int b[100000];
    int n,i;
    scanf("%d %d %d",&b[1],&b[2],&n);
    for(i=3;i<=n;i++)
        b[i]=b[i-1]*b[i-2];
    printf("%d\n",b[n]%10007);
    system("pause");
    return 0;

}  
这是我的代码,输入较小数字时还可以,但如果输入33 35 36时,我的结果就会出错。怎么改?
搜索更多相关主题的帖子: include 
2016-10-08 17:09
grmmylbs
Rank: 14Rank: 14Rank: 14Rank: 14
等 级:贵宾
威 望:54
帖 子:1409
专家分:5845
注 册:2016-2-14
收藏
得分:0 
for(i=3;i<=n;i++)
b[i]=b[i-1]*b[i-2]%10007;
2016-10-08 17:19
ehszt
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:40
帖 子:1745
专家分:3216
注 册:2015-12-2
收藏
得分:0 
也许是整型装不下b[n],int型最大正数为32767,不行换成unsigned int,再不行换成long
2016-10-08 17:21
NiuYoohoo
Rank: 4
等 级:业余侠客
威 望:2
帖 子:65
专家分:216
注 册:2016-10-8
收藏
得分:0 
回复 楼主 zhangx378
算法问题,导致溢出,你可以在计算中取mod,着这样最大的可能值为max=(mod_val-1)^2 ,显然题目中max<INT_MAX所以是可行的。
2016-10-08 17:25
NiuYoohoo
Rank: 4
等 级:业余侠客
威 望:2
帖 子:65
专家分:216
注 册:2016-10-8
收藏
得分:0 
当然前提是首项和第二项乘积不越界的情况下
2016-10-08 17:29
NiuYoohoo
Rank: 4
等 级:业余侠客
威 望:2
帖 子:65
专家分:216
注 册:2016-10-8
收藏
得分:0 
回复 3楼 ehszt
现在早过了32767的年代了吧
2016-10-08 17:30
zhangx378
Rank: 1
等 级:新手上路
帖 子:58
专家分:0
注 册:2016-9-29
收藏
得分:0 
回复 3楼 ehszt
都试了,没用
2016-10-08 17:32
ehszt
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:40
帖 子:1745
专家分:3216
注 册:2015-12-2
收藏
得分:0 
回复 6楼 NiuYoohoo
不好意思应该是2147483647。
2016-10-08 17:42
ehszt
Rank: 12Rank: 12Rank: 12
等 级:贵宾
威 望:40
帖 子:1745
专家分:3216
注 册:2015-12-2
收藏
得分:0 
回复 7楼 zhangx378
我得出的结果是5016不知道是不是你想要的结果。
另外,二楼的方法可以试试,可以减小数据的长度。
2016-10-08 17:45
zhangx378
Rank: 1
等 级:新手上路
帖 子:58
专家分:0
注 册:2016-9-29
收藏
得分:0 
回复 2楼 grmmylbs
谢谢,已解决。
2016-10-08 17:46
快速回复:数组长度不够
数据加载中...
 
   



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

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