国际象棋盘上共有64个格子,设想在象棋盘上放麦子。在第1个格子中放1粒,第2个格子中放2粒,第3个格子中放4粒,以后每一格都比前一格增加1倍,依此放完棋盘上的64个格子。请分别采用两种累加方法(直接计算累加的通项,利用前项计算后项)计算共需要多少粒麦子,这些麦子合多少立方米(已知1立方米麦子约1.42e8粒)。
(1)直接计算累加通项:
#include<math.h>
#include<stdio.h>
#define CONST 1.42e8 /*定义符号常量CONST的值为1.42e8*/
main()
{
int n;
double term,sum=0;
for(n=1;n<=64;n++);
{
term=pow(2,n-1);
sum=sum+term;
}
printf("sum=%e\n",sum); /*打印总麦粒数*/
printf("volum=%e\n",sum/CONST); /*打印折合的总数麦粒体积数*/
}
(2)利用前项计算后项:
#include<math.h>
#include<stdio.h>
#define CONST 1.42e8
main()
{
int n;
double term=1,sum=1;
for(n=2;n<=64;n++)
{
term=term*2;
sum=sum+term;
}
printf("sum=%e\n",sum);
printf("volum=%e\n",sum/CONST);
}