题解 | #求解立方根#

求解立方根

https://www.nowcoder.com/practice/caf35ae421194a1090c22fe223357dca

import java.util.Scanner;
import java.text.DecimalFormat;

// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        // 注意 hasNext 和 hasNextLine 的区别
        while (sc.hasNext()) { // 注意 while 处理多个 case
            Double d = sc.nextDouble();
            System.out.printf("%.1f",getResult(d));
        }
    }

    private static double getResult(double b) {
        boolean flag = true;
        if(b<0){
            b = - b;
            flag = false;
        }
        double mid =0.0,left=0.0,right=b; 
	  //当b小于1的时候,立方根比b大,但是比1小
        right = Math.max(b,1);
        while(right-left>0.01){
            mid = right - (right-left)/2;
            if(mid*mid*mid>b){
                right = mid;
            }else{
                left = mid;
            }
        }

        if(!flag){
            mid = -mid;
        }
        return mid;
    }
}

全部评论

相关推荐

头像
11-21 11:39
四川大学 Java
是红鸢啊:忘了还没结束,还有字节的5k 违约金
点赞 评论 收藏
分享
头像
11-06 10:58
已编辑
门头沟学院 嵌入式工程师
双非25想找富婆不想打工:哦,这该死的伦敦腔,我敢打赌,你简直是个天才,如果我有offer的话,我一定用offer狠狠的打在你的脸上
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务