69.x的平方根


69.x的平方根

给你一个非负整数 x ,计算并返回 x算术平方根

由于返回类型是整数,结果只保留 整数部分 ,小数部分将被 舍去 。

注意:不允许使用任何内置指数函数和算符,例如 pow(x, 0.5) 或者 x ** 0.5

示例 1:

输入:x = 4
输出:2

示例 2:

输入:x = 8
输出:2
解释:8 的算术平方根是 2.82842…, 由于返回类型是整数,小数部分将被舍去。

提示:

  • 0 <= x <= 231 - 1

题解:

class Solution {
    public int mySqrt(int x) {
        int ans = 0;
        int r = x;
        for (int i = 0; i <= r; ) {
            int middle = i + (r - i) / 2;
            if ((long)middle * middle <= x) {
                ans = middle;
                i = middle + 1;
            } else {
                r = middle - 1;
            }
        }
        return ans;
    }
}

文章作者: Feliks
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 Feliks !
评论
  目录