博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Leetcode 29. Divide Two Integers
阅读量:5113 次
发布时间:2019-06-13

本文共 2336 字,大约阅读时间需要 7 分钟。

29. Divide Two Integers

Total Accepted: 70841 Total Submissions: 448890 Difficulty: Medium

 

Divide two integers without using multiplication, division and mod operator.

If it is overflow, return MAX_INT.

 

思路:

dividend=a1*divisor+a2*divisor+...+an*divisor(ax为2k)。

以下情况造成溢出:

1.除数为0

2.被除数=INT_MIN,除数为-1

 

 

代码:

代码中只使用了int类型。注意INT_MIN=-2147483648,INT_MAX=2147483647。

1 class Solution { 2 public: 3     int divide(int dividend, int divisor) { 4         if(divisor==0||(dividend==INT_MIN&&divisor==-1)){ 5             return INT_MAX; 6         } 7         if(divisor==1){ 8             return dividend; 9         }10         if(dividend==INT_MIN){11             if(divisor&1){12                 return divide(dividend+1,divisor);13             }14             else{15                 return divide(dividend>>1,divisor>>1);16             }17         }18         if(divisor==INT_MIN){19             return 0;20         }21         //符号判断22         bool sign=(dividend<0)^(divisor<0);23         //这里要防止溢出,因此到这里要满足dividend!=INT_MIN,divisor!=INT_MIN24         if(dividend<0) dividend=-dividend;25         if(divisor<0) divisor=-divisor;26         int result=0,temp,tempd;27         while(dividend>=divisor){28             tempd=divisor;29             temp=1;30             //溢出判断31             while(INT_MAX>>1>=tempd&&dividend>=tempd){32                 tempd=tempd<<1;33                 temp<<=1;34             }35             if(dividend
>=1;37 temp>>=1;38 }39 dividend-=tempd;40 result+=temp;41 }42 return sign?-result:result;43 }44 };

 

 

或者:

1 class Solution { 2 public: 3     int divide(int dividend, int divisor) { 4         if (!divisor || (dividend == INT_MIN && divisor == -1)) 5             return INT_MAX; 6         int sign = ((dividend < 0) ^ (divisor < 0)) ? -1 : 1; 7         long long dvd = labs(dividend); 8         long long dvs = labs(divisor); 9         int res = 0;10         while (dvd >= dvs) { 11             long long temp = dvs, multiple = 1;12             while (dvd >= (temp << 1)) {13                 temp <<= 1;14                 multiple <<= 1;15             }16             dvd -= temp;17             res += multiple;18         }19         return sign == 1 ? res : -res; 20     }21 };

 

转载于:https://www.cnblogs.com/Deribs4/p/5635879.html

你可能感兴趣的文章
MySQL5.7开多实例指导
查看>>
[51nod] 1199 Money out of Thin Air #线段树+DFS序
查看>>
poj1201 查分约束系统
查看>>
Red and Black(poj-1979)
查看>>
分布式锁的思路以及实现分析
查看>>
腾讯元对象存储之文件删除
查看>>
jdk环境变量配置
查看>>
安装 Express
查看>>
包含列的索引:SQL Server索引的阶梯级别5
查看>>
myeclipse插件安装
查看>>
浙江省第十二届省赛 Beauty of Array(思维题)
查看>>
NOIP2013 提高组 Day1
查看>>
个人对vue生命周期的理解
查看>>
cocos2dx 3.x simpleAudioEngine 长音效被众多短音效打断问题
查看>>
存储(硬件方面的一些基本术语)
查看>>
观察者模式
查看>>
Weka中数据挖掘与机器学习系列之基本概念(三)
查看>>
Win磁盘MBR转换为GUID
查看>>
大家在做.NET B/S项目的时候多用什么设技术啊?
查看>>
Java SE和Java EE应用的性能调优
查看>>