华为OJ训练之0014-170102-计算立方根

题目

//•计算一个数字的立方根,不使用库函数
//详细描述:
//•接口说明
//原型:
//public static double getCubeRoot(double input)
//输入:double 待求解参数
//返回值:double 输入参数的立方根

============================================================

一次通过 100分

===========================================================

import java.util.Scanner;




//•计算一个数字的立方根,不使用库函数
//详细描述:
//•接口说明
//原型:
//public static double getCubeRoot(double input)
//输入:double 待求解参数
//返回值:double  输入参数的立方根


public class oj014 {

    public static double getCubeRoot(double input)
    {
        double x=input;
        double y=x/2;

//      求x的立方根,先假定初始值为y
//      随后用跌打y=y-(y^3-x)/(3*y*y) 进行迭代循环求出x的立方根y。
//      迭代次数越多,越接近真实值。误差=|y^3-x|

        while((y*y*y-x)<-0.0001||(y*y*y-x)>0.0001)
        {
        y=y-(y*y*y-x)/(3*y*y);
        }

        System.out.print(((int)y*10)/10.0);

        return y;

    }
    public static void main(String[] args) {

        Scanner scanner=new Scanner(System.in);
        double input=scanner.nextDouble();
        oj014.getCubeRoot(input);


    }

}

你可能感兴趣的:(华为OJ训练之0014-170102-计算立方根)