【leetcode算法刷题-剑指 Offer II】001. 整数除法(普通人可以看懂的代码,附java和go实现)

本文介绍了如何在不使用乘除和求余符号的情况下,通过减法和快速幂次方法解决整数除法问题。详细阐述了解题思路,并提供了Java和Golang两种语言的实现代码。
摘要由CSDN通过智能技术生成

剑指 Offer II 001. 整数除法

题目要求

leetcode地址

  • 剑指 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)

public static int divide(int a, int b) {
   
        //特殊情况直接处理
        if (a == Integer.MIN_VALUE &
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值