计算机根号40次方,开根号_乐鑫科技笔试题_牛客网

本文介绍了如何使用二分搜索算法改进求解n开m次方的问题,通过迭代逼近的方式,精确计算并返回最接近的值。重点在于理解为何需要m-1次除以中间值mid,并演示了整个过程的代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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;

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值