算法--牛顿迭代法

法一:

用二分查找找target 的中间值,就是target的平方根

java 复制代码
public int mySqrt(int x) {
        int l = 0, r = x;
        while (l <= r) {
            int mid = l + (r - l) / 2;
            if ((long) mid * mid <= x) {
                
                l = mid + 1;
            } else {
                r = mid - 1;
            }
        }
        return l-1;
    }

牛顿迭代法

解题思路参考:69. x 的平方根 - 力扣(LeetCode)

同样的方法可以用在其它的近似值计算中

java 复制代码
   public int mySqrt(int a) {
        long x = a;
        while (x * x > a) x = (x + a / x) / 2;
        return (int)x;
    }
相关推荐
earthzhang202136 分钟前
【1028】字符菱形
c语言·开发语言·数据结构·c++·算法·青少年编程
papership41 分钟前
【入门级-算法-3、基础算法:二分法】
数据结构·算法
hjlgs41 分钟前
Linux中双向链表介绍
数据结构·链表
通信小呆呆41 分钟前
收发分离多基地雷达椭圆联合定位:原理、算法与误差分析
算法·目标检测·信息与通信·信号处理
earthzhang20213 小时前
第3讲:Go垃圾回收机制与性能优化
开发语言·jvm·数据结构·后端·性能优化·golang
apocelipes3 小时前
golang unique包和字符串内部化
java·python·性能优化·golang
Full Stack Developme4 小时前
java.text 包详解
java·开发语言·python
刘梦凡呀5 小时前
C#获取钉钉平台考勤记录
java·c#·钉钉
丁浩6665 小时前
Python机器学习---2.算法:逻辑回归
python·算法·机器学习
best_virtuoso5 小时前
PostgreSQL 常见数组操作函数语法、功能
java·数据结构·postgresql