剑指 Offer II 001. 整数除法
题目要求
- 剑指 Offer II 001. 整数除法
- 简单
- 253
- 给定两个整数 a 和 b ,求它们的除法的商 a/b ,要求不得使用乘号 ‘*’、除号 ‘/‘ 以及求余符号 ‘%’ 。
注意
- 整数除法的结果应当截去(truncate)其小数部分,例如:truncate(8.345) = 8 以及 truncate(-2.7335) = -2
- 假设我们的环境只能存储 32 位有符号整数,其数值范围是 [−2 ^ 31,2 ^ 31 -1 ]。本题中,如果除法结果溢出,则返回 2^31 − 1
示例 1:
输入:a = 15, b = 2
输出:7
解释:15/2 = truncate(7.5) = 7
示例 2:
输入:a = 7, b = -3
输出:-2
解释:7/-3 = truncate(-2.33333..) = -2
示例 3:
输入:a = 0, b = 1
输出:0
示例 4:
输入:a = 1, b = 1
输出:1
- 提示:
- -2 ^ 31 <= a, b <= 2 ^ 31 - 1
- b != 0
*/
思路
题目要求只能使用加减法,那我们自然想到用减法实现除法,用“被减数”能减去几次“减数”来衡量最后的结果,这时候我们想到求x的幂次的快速解法,将x成倍成倍的求幂,这里将减数成倍成倍的增大,次数对应也是成倍成倍的增大,例如:取a=23,b=2,b的变化如下:2->4->8->16,次数count的变化如下1->2->4->8,最后a-b=23-16=7,对7再执行一次上述过程,b:2->4,count:1->2,a-b=3, 然后对3再执行一次,b:2,count:1,a-b=1,1已经小于原b=2,可以结束了,最后计数一下每轮的count是多少8+2+1=11。
注意事项
为方便运算,我们需要将a,b都转为同正or同负,由于INT_MIN转正就越界了,我们只好都转负,这也是都转负的原因,有一种特殊情况 INT_MIN/(-1)就overflow了 所以直接特殊处理最终结果的正负。
代码实现(java)
1 |
|
代码实现(golang)
1 |
|
剑指 Offer II 001. 整数除法
https://liuxx1106.github.io/2023/07/14/algorithm-offer001/