leetcode_两数相除

本文详细介绍了一种基于位操作的两数相除算法实现,通过将正数转化为负数,利用位移和循环来寻找最大除数倍数,从而避免了传统除法运算可能引起的溢出问题。

两数相除跳转
在这里插入图片描述

	public int divide(int dividend, int divisor) {
		//标记符号
		boolean flag = dividend > 0 ^ divisor > 0;
		//最后结果
		int total = 0;
		//化为负数
		if (divisor > 0)
			divisor = -divisor;
		if (dividend > 0) {
			dividend = -dividend;
		}
		//相同的值,直接返回
		if (dividend == divisor)
			return flag ? -1 : 1;
		//大于半数的值,直接返回
		if (divisor <= Integer.MIN_VALUE >> 1 && dividend < divisor)
			return flag ? -1 : 1;
		//寻找到一个最大的除数的倍数
		int i;
		for (i = 0; i < 31; i++) {
			if (!(dividend < divisor << i && divisor << i > Integer.MIN_VALUE >> 1)) {
				break;
			}
		}
		i--;
		//从最大的依次往下减
		for (; i >= 0; i--) {
			int td = divisor << i;
			while (dividend <= td) {
				dividend = dividend - td;
				total += -1 << i;
				td = divisor << i;
			}
		}
		//异号直接返回,整数之间不存在溢出
		if (flag)
			return total;
		//本处其实只针对 -2147483648 和 -1 这一种情况
		if (total == Integer.MIN_VALUE)
			return Integer.MAX_VALUE;
		//同号返回
		return -total;
	}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值