LeetCode (29)Divide Two Integers

31 篇文章 0 订阅

(29)Divide Two Integers

题目:不用除法计算一个数与另一个数的商。

另外:当结果溢出int范围的时候,输出int范围最大的数字。

例如:

输入:dividend:-10;divisor:-1;
输出:10。

输入:dividend:-2147483648;divisor:1;
输出:-2147483648。

本来题目还是挺简单的,但是就这个int范围搞得有点烦。

除法就是减法的简单方法,然而如果直接使用减法做多次删减的工作,会导致TLE,所以使用位运算的方法,可以将除数每次做2的倍数的运算,每次减去这个数,就可以算出商是多少了。这样就从O(n)的算法变成O(logn)的算法,减少不少时间。

下面是代码:

class Solution {
public:
    int divide(int dividend, int divisor) {
        if(dividend == 0 || divisor == 0){
            return 0;
        }
        unsigned int dividend_abs = abs(dividend),
            divisor_abs = abs(divisor);
        int flag = (dividend < 0) ^ (divisor < 0);
        int len = 0;
        while(divisor_abs < dividend_abs){
            divisor_abs = divisor_abs << 1;
            len ++;
        }
        unsigned int temp = divisor_abs;
        temp = temp >> 1;
        divisor_abs = divisor_abs >> len;
        len --;
        if(len == -1){
            return (divisor_abs > dividend_abs)?(0):(flag==0?1:(0-1));
        }
        dividend_abs -= temp;
        int result = 1 << len;
        while(len >= 0){
            if(temp <= dividend_abs){
                dividend_abs -= temp;
                result += 1 << len;
            }
            else{
                len --;
                temp = temp >> 1;
            }
        }
        if(result < -2147483647 || result > 2147483647){
            return flag==0?2147483647:-2147483648;
        }
        return flag==0?(result):(0-result);
    }
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值