题目

类型:二分搜索
难度:简单
image.png

解题思路

方法一:袖珍计算器算法

image.png

方法二:二分查找

image.png

代码

方法一:

  1. class Solution {
  2. public int mySqrt(int x) {
  3. if (x == 0) {
  4. return 0;
  5. }
  6. int ans = (int) Math.exp(0.5 * Math.log(x));
  7. return (long) (ans + 1) * (ans + 1) <= x ? ans + 1 : ans;
  8. }
  9. }

方法二:

class Solution {
    public int mySqrt(int x) {
        int l = 0, r = x, ans = -1;
        while (l <= r) {
            int mid = l + (r - l) / 2;
            if ((long) mid * mid <= x) {
                ans = mid;
                l = mid + 1;
            } else {
                r = mid - 1;
            }
        }
        return ans;
    }
}