C语言,计算1到100之间所有偶数的乘积并输出.
3个回答
展开全部
由于结果是很大很大的整数,所以必须用大数处理办法解决。先计算出结果大约是多少位十进制数,再据此动态申请数组空间。又由于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;
}
执行结果如下图:
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类型,不然会溢出。
main()
{
double p=1.0,i;
for(i=2;i<=100;i+=2)
p *= i;
printf("Product is %lf\n",p);
}
必须用double类型,不然会溢出。
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
2014-01-01
展开全部
#include
int main(void)
{
int i,s;
s=0;
for(i=2;i<=100;i+=2)
s+=i;
printf("%d",s);
}
int main(void)
{
int i,s;
s=0;
for(i=2;i<=100;i+=2)
s+=i;
printf("%d",s);
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询