Leetcode69.x的平方根
给你一个非负整数 x
,计算并返回 x
的 算术平方根 。
由于返回类型是整数,结果只保留 整数部分 ,小数部分将被 舍去 。
示例 1:
输入:x = 4
输出:2
示例 2:
输入:x = 8
输出:2
解释:8 的算术平方根是 2.82842…, 由于返回类型是整数,小数部分将被舍去。
class Solution {
public int mySqrt(int x) {
//定义左区间和右区间
int left=1;
int right=x;
//二分法
while(left<=right){
int middle=left+((right-left)>>1);
//使用x/middle的原因是不会越界,如果middle*middle>2^31-1则会出错
if(x/middle<middle){
right=middle-1;
}else if(x/middle>middle){
left=middle+1;
}else{
return middle;
}
}
return right;
}
}