forked from doocs/leetcode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathSolution.java
36 lines (32 loc) · 1.02 KB
/
Solution.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
class Solution {
public int divide(int dividend, int divisor) {
if(dividend == 0 || divisor == 1) {
return dividend;
}
if(divisor == 0 || (dividend == Integer.MIN_VALUE && divisor == -1)) {
return Integer.MAX_VALUE;
}
// 商的符号,true 为正,false 为负
boolean flag = true;
if((dividend < 0 && divisor > 0) || (dividend > 0 && divisor < 0)) {
flag = false;
}
long dividendLong = Math.abs((long)dividend);
long divisorLong = Math.abs((long)divisor);
int re = 0;
long factor = 0x1;
while (dividendLong >= (divisorLong << 1)) {
divisorLong <<= 1;
factor <<= 1;
}
while (factor > 0 && dividendLong > 0) {
if(dividendLong >= divisorLong) {
dividendLong -= divisorLong;
re += factor;
}
factor >>>= 1;
divisorLong >>>= 1;
}
return flag ? re : -re;
}
}