题目链接
题目描述
实现 int sqrt(int x)
函数。
计算并返回 x 的平方根,其中 x 是非负整数。
由于返回类型是整数,结果只保留整数的部分,小数部分将被舍去。
示例 1:
输入: 4
输出: 2
示例 2:
输入: 8
输出: 2
说明: 8 的平方根是 2.82842…,
由于返回类型是整数,小数部分将被舍去。
解题思路
方法一:二分查找
class Solution {
public:
int mySqrt(int x) {
// 右边为x/2+1,减少循环
int l = 0, r = x/2+1, ans = -1;
while (l <= r) {
int mid = l + (r - l) / 2;
// 强制类型转换,截取long long部分数据
if ((long long)c * mid <= x) {
ans = mid;
l = mid + 1;
} else {
r = mid - 1;
}
}
return ans;
}
};
- 时间复杂度 O(log n)
- 空间复杂度 O(1)
方法二:牛顿迭代法
牛顿迭代法是一个可以求一个任意函数的零点的工具。它比二分法快得多。
求x的平方根相当于求f(x) = x^2 - C为0时的x,进而转为求零点问题。
绝对值小于1e-7视为等于0
class Solution {
public:
int mySqrt(int x) {
if (x == 0) {
return 0;
}
double C = x, x0 = x;
while (true) {
double xi = 0.5 * (x0 + C / x0);
if (fabs(x0 - xi) < 1e-7) {
break;
}
x0 = xi;
}
return int(x0);
}
};
- 时间复杂度 O(log n) 比二分查找更快。
- 空间复杂度 O(1)