根号10在Java中写成_开根号_乐鑫科技笔试题_牛客网

import java.util.*;

public class Main{

public static void main(String[] args){

Scanner sc = new Scanner(System.in);

Main main = new Main();

double n = sc.nextDouble();

int m = sc.nextInt();

System.out.println(main.mySqrt(n, m));

}

private double mySqrt(double n, int m){

/*

我这里输入跟题目给的不一样,n 是 m,而 m 是 n

我们使用二分逼近的方法

首先 mid = (left + right) >>> 1;

然后将 n 除以 mid ,m - 1 次

为啥?因为我们要跟 mid 进行比较,判断 mid 是否是适合 n 开 m 次方后的数

比如 n 开方,那么我们只需要 n 除以 mid 一次即可,然后将结果跟 mid 比较

如果接近,那么继续逼近

同时,我们可以换做是 m 个 mid 相乘,然后跟 n 进行比较,一样的思路

只不过一个是乘,一个是除

*/

double pre = 0;

double left = 0;

double right = n;

//迭代精准度

double eps = 1e-12;

while(right - left > eps || left - right > eps){

double mid = (left + right) / 2;

double temp = 1;

for(int i = 0; i 

temp *= mid;

}

if(temp > n){

right = mid;

}else{

left = mid;

}

pre = mid;

}

return pre;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值