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

网站建设与维护毕业论文新闻头条今日要闻10条

网站建设与维护毕业论文,新闻头条今日要闻10条,网站建设价格表,黑群晖做网站✅ LeetCode 29. 两数相除 — 思路总览 🧩 题目要求 给定两个整数 dividend 和 divisor,实现 整数除法,不能使用乘法 *、除法 / 和取余 % 运算符。 要求返回的结果应为 向零截断的整数商,即: 正数向下取整&#xf…

在这里插入图片描述

✅ 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会超过ldividendwhile(ldividend > (temp << 1)) { temp <<= 1;multiple <<= 1;}ldividend -= temp;result += multiple;}return negative ? -result : result;}
}
http://www.dtcms.com/wzjs/135703.html

相关文章:

  • 做编程的 网站网站策划是做什么的
  • 网站页面做专题的步骤软件推广平台有哪些
  • 东莞定制网站建设军事网站大全军事网
  • 网站适配手机怎么做深圳seo顾问
  • 图书电子商务网站建设长春seo结算
  • 南坪做网站腾讯广告投放推广平台价格
  • 郑州做网站公司+卓美长春网络推广公司哪个好
  • 网站建设 大公司小公司最新搜索引擎排名
  • wordpress 替代文本网站seo优化的目的
  • 程序员网站开发框架灰色词网站seo
  • 专门做面条菜谱的网站百度热门排行榜
  • 青岛网站开发哪家服务专业广州推广服务
  • wordpress 图文展示石家庄seo网络推广
  • 中小企业网络安全网站seo教材
  • 北京哪里可以做网站百度销售岗位怎么样
  • 现在网站要怎么做才有人seo公司外包
  • 网站一年多少费用平台连接
  • 网站建设的技术可行性分析免费浏览外国网站的软件
  • 视频聊天网站怎么建设seo是什么工作内容
  • 网页设计topseo推广软件排行榜
  • 俄罗斯b2b网站大全宁波seo快速优化教程
  • 网页数据可视化设计案例怎么进行seo
  • 西安+医疗网站建设三十个知识点带你学党章
  • 住房和城乡建设部网站八大员北京中文seo
  • wordpress全能播放器代码百度seo排名帝搜软件
  • 网站css在线生成西安网站搭建公司
  • 做网站柳州网站开发工具
  • 网站注销备案邀请推广app
  • 深圳婚纱摄影网站建设起名最好的网站排名
  • 杭州网站建设制作刷排名seo软件