方法一:找各项规律,2^0+2^1+2^2+....2^63。

  1. 用double来存储数据,因为int是4字节,取值范围是-2^31~2^31-1,不能满足需求。
  2. pow(x,y) 其作用是计算x的y次方,x、y及函数值都是double型 。注意的是,需要加入头文件 math.h。
  3. %e 以指数形式输出 float 类型,也可以用%f来输出float 类型。
/* 函数功能:国王的许诺,需要多少麦子,这些麦子合多少立方米*/
#include <stdio.h>
#include <math.h>
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 <stdio.h>

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;
}

运行结果如下:

 

 

更多推荐

【C语言作业3】国王的许诺:需要多少麦子?这些麦子合多少立方米?