C语言,计算1到100之间所有偶数的乘积并输出.

如题所述

由于结果是很大很大的整数,所以必须用大数处理办法解决。先计算出结果大约是多少位十进制数,再据此动态申请数组空间。又由于9999999*100仍未超出int范围,所以用求出的位数除以7向上取整作为申请int数组的长度,将每个数组元素视作10000000进制单元操作,单元内部按十进制计数;操作完成后由高位到低位依次将各元素数据输出到屏幕连成一个大数。举例代码如下:

#include "stdio.h"
#include "stdlib.h"
#include "math.h"
int main(int argc,char *argv[]){
double x;
int i,k,n,*p;
for(x=0,i=2;i<101;x+=log10(i),i+=2);//计算最后结果的十进制位数
n=int(x/7)+!!(x-int(x));//n对x/7向上取整
if((p=(int *)malloc(sizeof(int)*(n=(int(x)+1)/7+1)))==NULL){//申请数组空间
printf("Application memory failure...\n");
return 0;
}
for(k=0;k<n;p[k++]=0);//空间清0
for(p[--n]=2,i=4;i<101;i+=2){//完成2*4*6*...*100的计算
for(k=n;k>=0;p[k--]*=i);//每位乘以i存入本位
for(k=n;k>0;k--)//检查处理进位
if(p[k]>9999999)
p[k-1]+=p[k]/10000000,p[k]%=10000000;
}
printf("\n2*4*6*...*100 = %d",p[0]);//输出最高7位数并删除前导0
for(i=1;i<=n;printf("%07d",p[i++]));//后续输出必须包括前导0
free(p);
printf("\n");
return 0;
}

执行结果如下图:

温馨提示:答案为网友推荐,仅供参考
第1个回答  2014-01-01
#include <stdio.h>
main()
{
double p=1.0,i;
for(i=2;i<=100;i+=2)
p *= i;
printf("Product is %lf\n",p);
}

必须用double类型,不然会溢出。本回答被网友采纳
第2个回答  2014-01-01
#include
int main(void)
{
int i,s;
s=0;
for(i=2;i<=100;i+=2)
s+=i;
printf("%d",s);
}
相似回答