[LeetCode] 69. x 的平方根

我都不好意思写 我没想出来二分法。。。。

方法一:二分法

public class Solution {

    public int mySqrt(int x) {
        long left = 0;
        long right = Integer.MAX_VALUE;
        while (left < right) {
            // 这种取中位数的方法又快又好,是我刚学会的,原因在下面这篇文章的评论区
            // https://www.liwei.party/2019/06/17/leetcode-solution-new/search-insert-position/
            // 注意:这里得用无符号右移
            long mid = (left + right + 1) >>> 1;
            long square = mid * mid;
            if (square > x) {
                right = mid - 1;
            } else {
                left = mid;
            }
        }
        return (int) left;
    }
}

[LeetCode] 69. x 的平方根

 

上一篇:修改jsp页面内容tomcat报错


下一篇:前端每日实战:69# 视频演示如何用纯 CSS 创作一个单元素抛盒子的 loader