C语言。要输入一个超大数比如 111111111111111111111111111111111111111 怎样用字符串数组求各位的和呢?
这个超大数不是10的100次方个数,而是一个数,只不过有100位,那么我们会用一个整型的数据存储,但没有相应的整型类型能存放这么大的数。 问题是: -如果你想保留这个数,那么用一个字符串数组来存储每一位上的数字是可以的。 -你想计算是否能被3整除,那么你可以利用一个数学定理来完成这个计算,无需大内存,只要一小段程序即可,即:一个数能被3整除,那么这个数的每位上的数字的和能被3整除,比如12的两位数字之和是3,3能被3整除,那么12也能,21一样也能210,21000,同理都可以。 那么你的计算就无需等待这个数都输入后再开始,而可以从每一位刚输入时就可以了。 见下面程序:int n,...全部
这个超大数不是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='0' && b a[j]=(b-'0'); c =a[j]; //将输入的字符转换成数字,加到累加和上}if ( c%3 ) printf("No
"); else printf("Yes
");。收起