题目描述
•计算一个数字的立方根,不使用库函数
详细描述:
•接口说明
原型:
public static double getCubeRoot(double input)
输入:double 待求解参数
返回值:double 输入参数的立方根
输入描述:
待求解参数 double类型
输出描述:
输入参数的立方根 也是double类型
算法实现:
package com.husweijishi.suanfa;
import java.math.BigDecimal;
import java.text.DecimalFormat;
import java.util.Scanner;
/**
* 求解一个数的立方根
* @author liyongyong
* 2016年12月4日
*/
public class LiFangGen {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
while(scanner.hasNext()){
double num = scanner.nextDouble();
System.out.println(getLiFangGen(num));
}
}
/**
* 利用牛顿法求解一个数的立方根
* @param num
*/
private static double getLiFangGen(double num) {
if (num == 0) {
return num;
}
double num1,num2;
num1 = num;
num2 = (2*num1/3)+(num/(num1*num1*3));//利用牛顿迭代法求解
while(Math.abs(num2-num1)>0.000001){
num1=num2;
num2=(2*num1/3)+(num/(num1*num1*3));
}
DecimalFormat df = new DecimalFormat("#.0");
return Double.parseDouble(df.format(num2));
}
}