满意答案
muwen3798
2014.01.04
采纳率:45% 等级:13
已帮助:9415人
这个超大数不是10的100次方个数,而是一个数,只不过有100位,那么我们会用一个整型的数据存储,但没有相应的整型类型能存放这么大的数。
问题是:
-如果你想保留这个数,那么用一个字符串数组来存储每一位上的数字是可以的。
-你想计算是否能被3整除,那么你可以利用一个数学定理来完成这个计算,无需大内存,只要一小段程序即可,即:一个数能被3整除,那么这个数的每位上的数字的和能被3整除,比如12的两位数字之和是3,3能被3整除,那么12也能,21一样也能210,21000,同理都可以。那么你的计算就无需等待这个数都输入后再开始,而可以从每一位刚输入时就可以了。见下面程序:
int n,b,c=0,j; char a[101];
scanf("%d",&n);
for ( j=0;j
{ do { b=getchar(); } while ( !(b>='0' && b<='9') ); //保证输入一位数字,输入整个大数后回车即可
a[j]=(b-'0'); c+=a[j]; //将输入的字符转换成数字,加到累加和上
}
if ( c%3 ) printf("No\n"); else printf("Yes\n");
00分享举报