首页 > 代码库 > 考察数据类型的掌握---题目1166:迭代求立方根 (2009年北京航空航天大学计算机研究生机试真题)

考察数据类型的掌握---题目1166:迭代求立方根 (2009年北京航空航天大学计算机研究生机试真题)

题目描述:

立方根的逼近迭代方程是 y(n+1) = y(n)*2/3 + x/(3*y(n)*y(n)),其中y0=x.求给定的x经过n次迭代后立方根的值。

输入:

输入有多组数据。
每组一行,输入x n。

输出:

迭代n次后的立方根,double精度,保留小数点后面六位。

样例输入:
3000000 28
样例输出:
144.224957


#include "stdio.h"
 
int main(int argc, char* argv[])
{
    long n;
    double x;
    while(scanf("%lf%d",&x,&n)!=EOF){
        double temp=x;
        while(n>0){
             x = x*2/3 + temp/(3*x*x);    // y(n+1) = y(n)*2/3 + x/(3*y(n)*y(n))
             n--;
        }
        printf("%.6lf\n",x);
    }
    return 0;
}
 
归纳:printf的%f说明符的确既可以输出float型又可以输出double型。根据“默认参数提升”规则float型会被提升为double型。因此printf()只会看到双精度数。对于scanf,它接受指针,没有类似的类型提升。向float存储和向double存储大不一样,因此,scanf区别%f和%lf。