Leetcode - Divide Two Integers

My code:

public class Solution {
    public int divide(int dividend, int divisor) {
        if (divisor == 0 || (dividend == Integer.MIN_VALUE && divisor == -1)) {
            return Integer.MAX_VALUE;
        }
        int sign = (dividend < 0 == divisor < 0 || dividend == 0) ? 1 : -1;
        long num = Math.abs((long) dividend);
        long div = Math.abs((long) divisor);
        int sum = 0;
        while (num >= div) {
            long temp = div;
            long counter = 1;
            while (num >= (temp << 1)) {
                temp <<= 1;
                counter <<= 1;
            }
            num -= temp;
            sum += counter;
        }
        
        return sign * sum;
    }
}

reference:
https://discuss.leetcode.com/topic/15568/detailed-explained-8ms-c-solution

这道题目没能自己做出来。觉得太麻烦了。
其实和 Fraction to Recurring Decimal 差不多。
只不过那道题目关注的是小数点循环。
这道题目关注的是,如何更快地算出结果。
那自然是 Binary search, 但是是双层循环。这是我没能想到的。

Anyway, Good luck, Richardo! -- 09/22/2016

你可能感兴趣的:(Leetcode - Divide Two Integers)