❤️博客主页: 楚生辉
❤️系列专栏:【LeetCode刷题】
❤️一句短话: 坚持不懈,孜孜不倦
1.题目描述
给你一个非负整数 x ,计算并返回 x 的 算术平方根 。
由于返回类型是整数,结果只保留 整数部分 ,小数部分将被舍去 。
注意:不允许使用任何内置指数函数和算符,例如 pow(x, 0.5) 或者 x ** 0.5
示例 1
输入:x = 4
输出:2
示例 2
输入:x = 8
输出:2
解释:8 的算术平方根是 2.82842..., 由于返回类型是整数,小数部分将被舍去。
提示
0 <= x <= 2^31 - 1
2.代码实现
问题:这道题该怎么样与二分查找相联系起来?
由于 x 平方根的整数部分 ans 是满足 k^2 ≤ x 的最大 k 值,因此我们可以对 k 进行二分查找,从而得到答案。
二分查找的下界为 00,上界可以粗略地设定为 x。在二分查找的每一步中,我们只需要比较中间元素 mid 的平方与 x 的大小关系,并通过比较的结果调整上下界的范围。由于我们所有的运算都是整数运算,不会存在误差,因此在得到最终的答案 ans 后,也就不需要再去尝试 ans+1 了。
class Solution {
public int mySqrt(int x) {
int left = 0,right = x,ans = -1;
while (left <= right){
int mid = left + (right - left) / 2;
if((long)mid*mid > x){
right = mid - 1;
}else {
ans = mid;
left = mid + 1;
}
}
return ans;
}
}
| left | right | mid | ans |
|---|---|---|---|
| 0 | 8 | 4 | |
| 0 | 3 | 1 | ans = 1 |
| 1 | 3 | 2 | ans = 2 |
| 2 | 3 | 2 | ans = 2 |
| 3 | 3 | 3 | |
| 3 | 2 | 3 |
最后跳出循环,返回ans的值
本文介绍如何利用二分查找思想解决LeetCode上的算术平方根问题,通过整数比较不断缩小区间找到整数x的精确平方根,适合初学者理解基础算法应用。

被折叠的 条评论
为什么被折叠?



