-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy pathSolution069.java
38 lines (34 loc) · 901 Bytes
/
Solution069.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
package algorithm.leetcode;
/**
* @author: mayuan
* @desc:
* @date: 2018/08/19
*/
public class Solution069 {
public static void main(String[] args){
Solution069 test = new Solution069();
System.out.println(test.mySqrt(1));
System.out.println(test.mySqrt(2));
System.out.println(test.mySqrt(3));
System.out.println(test.mySqrt(4));
System.out.println(test.mySqrt(9));
}
public int mySqrt(int x) {
if (1 >= x) {
return x;
}
int left = 1, right = x;
while (left <= right) {
int mid = left + (right - left) / 2;
int sqrt = x / mid;
if (sqrt == mid) {
return sqrt;
} else if (sqrt < mid) {
right = mid - 1;
} else {
left = mid + 1;
}
}
return right;
}
}