当前位置: 首页 > news >正文

Leetcode 两数相除

在这里插入图片描述

✅ LeetCode 29. 两数相除 — 思路总览

🧩 题目要求

给定两个整数 dividenddivisor,实现 整数除法不能使用乘法 *、除法 / 和取余 % 运算符

要求返回的结果应为 向零截断的整数商,即:

  • 正数向下取整(如 8.3 → 8)
  • 负数向上取整(如 -8.3 → -8)

如果商超出 int 范围(即 < -2³¹ 或 > 2³¹ - 1),返回 Integer.MAX_VALUE


📌 解题思路

1️⃣ 特殊情况处理

  • 如果 dividend = Integer.MIN_VALUEdivisor = -1,结果将溢出,需返回 Integer.MAX_VALUE

2️⃣ 记录结果正负号

  • 用异或运算 (dividend < 0) ^ (divisor < 0) 判断结果是否为负数。
  • 将除数和被除数都转成正数进行计算,最后再加上符号。

3️⃣ 使用 减法 + 位运算(左移) 模拟除法

  • 使用 位移(<<)运算模拟乘法,通过将 divisor 不断翻倍来逼近 dividend
  • 在每一轮中:
    • 找出最大 divisor × 2^k,使得该值不超过当前 dividend
    • 将该倍数加入到最终结果中
    • dividend 减去该倍数的值,继续下一轮

4️⃣ 为什么使用 long?

  • 避免 Math.abs(Integer.MIN_VALUE) 溢出问题
  • 整个过程用 long 类型进行中间计算更安全,最后再强转为 int

⏱️ 时间复杂度分析

  • 每一轮减法都用 指数方式减少 dividend,因此时间复杂度为:
O(log N),N 为 dividend 的绝对值

✅ 关键点总结

点位说明
🚫 不使用 * / %用减法和位移代替
⚠️ 特判溢出MIN_VALUE / -1 会溢出
📈 位运算加速倍增 divisor 快速逼近
💡 先判断再左移(temp << 1) 防越界
🔒 使用 long 类型防止中间计算溢出

java solution

class Solution {
    public int divide(int dividend, int divisor) {
        // 处理特殊溢出情况, 当被除数是-2^31且除数是-1时, 此时得到的结果会溢出
        if(dividend == Integer.MIN_VALUE && divisor == -1) {
            return Integer.MAX_VALUE;
        }
        // 记录结果正负
        boolean negative = (dividend < 0) ^ (divisor < 0);

        // 使用 long 转换避免溢出,并且将被除数和除数都转换成正数,
        long ldividend = Math.abs((long) dividend);
        long ldivisor = Math.abs((long) divisor);

        int result = 0;
        // 我们利用内层的while循环来快速找到不超过ldividend的最大的ldivisor * 2^k, 
        while(ldividend >= ldivisor) { //这里是大于等于, 因为如果被除数等于除数时,还能继续减
            long temp = ldivisor;
            int multiple = 1; //multiple是不超过ldividend的最大的ldivisor * 2^k中2^k的值
//之所以这里while循环判断条件里是(temp << 1)而不是ldividend > temp
//是因为如果是后者, 那么我们得到的最终的temp会超过ldividend
            while(ldividend > (temp << 1)) { 
                temp <<= 1;
                multiple <<= 1;
            }
            ldividend -= temp;
            result += multiple;
        }
        return negative ? -result : result;
    }
}
http://www.dtcms.com/a/98514.html

相关文章:

  • 海量数据处理
  • 下载和初步上手Vue3路由
  • NOIP2007提高组.矩阵取数游戏
  • 思维链技术(Chain-of-Thought, CoT)
  • 双卡 RTX 5090 深度体验:AI 推理框架选择与性能限制实测
  • HCIP(RSTP+MSTP)
  • 【STL】list
  • React程序打包与部署
  • JAVASE-day14
  • 蓝桥杯备考:多米诺骨牌
  • 【Linux】GDB调试指南
  • 基于YALMIP+CPLEX的带储能微电网调度问题最优求解matlab仿真
  • 提示词工程(Prompt Engineering):释放AI潜能的“语言编程”
  • #CX# UVM中的virtual sequence 和 virtual sequencer 的用途
  • 【Kafka】从理论到实践的深度解析
  • pytorch中dataloader自定义数据集
  • Java/Scala是什么
  • 解决由于中文路径无法安装软件的问题--例如postersql
  • 数据化管理(一)---什么是数据化管理
  • 模拟集成电路设计与仿真 : Memory
  • 北斗导航 | 中国北斗卫星导航系统的发展历程——“三步走”战略:背景,信号频点,调制方式,短报文,等
  • Linux交叉编译第三方库,C语言调用第三方库
  • 资产收益数据处理与分析
  • RK3568 GPIO子系统
  • 自然语言模型的演变与未来趋势:从规则到多模态智能的跨越
  • 混合知识表示系统框架python示例
  • PyQt6实例_批量下载pdf工具_主线程停止线程池
  • PERL开发环境搭建>>Windows,Linux,Mac OS
  • 【JavaScript】九、JS基础练习
  • torch.tensor 用法