方法一:找各项规律,2^0+2^1+2^2+....2^63。
- 用double来存储数据,因为int是4字节,取值范围是-2^31~2^31-1,不能满足需求。
- pow(x,y) 其作用是计算x的y次方,x、y及函数值都是double型 。
注意的是,需要加入头文件 math.h。
- %e 以指数形式输出 float 类型,也可以用%f来输出float 类型。
/* 函数功能:国王的许诺,需要多少麦子,这些麦子合多少立方米*/
#include
#include
int main()
{
int n;
double sum;
sum=0;
for(n=0;n<64;n++)
{
sum=sum+pow(2,n);
}
printf("%e\n",sum);
printf("%e\n",sum/1.42e8);
return 0;
}
方法二:找出每项的联系,每一项是前一项×2所得。
/* 函数功能:国王的许诺,需要多少麦子,这些麦子合多少立方米*/
#include
int main()
{
int n;
double i;
double sum;
sum=1;
i=1;
for(n=0;n<63;n++)
{ i=2*i;
sum=sum+i;
}
printf("%e\n",sum);
printf("%e\n",sum/1.42e8);
return 0;
}
运行结果如下:
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)