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

深圳模板网站建设哪家好购买链接平台

深圳模板网站建设哪家好,购买链接平台,代做毕业设计的网站好,做服装团购有哪些网站ps:题目来自力扣 两数相除 给你两个整数,被除数 dividend 和除数 divisor。将两数相除,要求 不使用 乘法、除法和取余运算。 整数除法应该向零截断,也就是截去(truncate)其小数部分。例如,8.345 将被截断…

ps:题目来自力扣

两数相除

给你两个整数,被除数 dividend 和除数 divisor。将两数相除,要求 不使用 乘法、除法和取余运算。

整数除法应该向零截断,也就是截去(truncate)其小数部分。例如,8.345 将被截断为 8 ,-2.7335 将被截断至 -2 。

返回被除数 dividend 除以除数 divisor 得到的  。

注意:假设我们的环境只能存储 32 位 有符号整数,其数值范围是 [−231,  231 − 1] 。本题中,如果商 严格大于 231 − 1 ,则返回 231 − 1 ;如果商 严格小于 -231 ,则返回 -231 。

class Solution {public int divide(int dividend, int divisor) {// 处理边界情况,当被除数为最小值且除数为 -1 时,结果会超出 32 位有符号整数范围,直接返回最大值if (dividend == Integer.MIN_VALUE && divisor == -1) {return Integer.MAX_VALUE;}// 判断结果的符号,通过异或运算判断两数符号是否不同boolean negative = (dividend ^ divisor) < 0;// 将被除数和除数都转换为负数,因为负数的范围更大,能避免溢出问题dividend = -Math.abs(dividend);divisor = -Math.abs(divisor);int result = 0;while (dividend <= divisor) {int tempDivisor = divisor;int multiple = 1;// 不断将除数翻倍,同时倍数也翻倍,直到翻倍后的除数大于当前被除数while (dividend - tempDivisor <= tempDivisor) {tempDivisor <<= 1;multiple <<= 1;}// 减去当前能减去的最大的除数倍数dividend -= tempDivisor;// 累加对应的倍数到结果中result += multiple;}// 根据之前判断的符号,决定结果的正负return negative ? -result : result;}
}

代码解释

本题要求在不使用乘法、除法和取余运算的情况下,计算两个整数的商,并且要考虑 32 位有符号整数的范围。我们可以采用减法和位运算的方法来模拟除法。

具体步骤

  1. 处理边界情况
    • 当被除数为 Integer.MIN_VALUE 且除数为 -1 时,商为 Integer.MAX_VALUE + 1,会超出 32 位有符号整数的范围,所以直接返回 Integer.MAX_VALUE
  2. 判断结果的符号
    • 通过异或运算 (dividend ^ divisor) < 0 判断被除数和除数的符号是否不同,如果不同则结果为负。
  3. 将被除数和除数转换为负数
    • 为了避免溢出问题,将被除数和除数都转换为负数,因为负数的范围比正数大。
  4. 模拟除法过程
    • 使用 while 循环,只要被除数小于等于除数,就继续进行除法操作。
    • 在每次循环中:
      • 初始化临时除数 tempDivisor 为除数,倍数 multiple 为 1。
      • 不断将 tempDivisor 翻倍,同时 multiple 也翻倍,直到 tempDivisor 大于当前被除数。
      • 用被除数减去 tempDivisor,并将 multiple 累加到结果 result 中。
  5. 根据符号返回结果
    • 根据之前判断的符号,决定最终结果的正负,如果为负则返回 -result,否则返回 result
http://www.dtcms.com/wzjs/163790.html

相关文章:

  • 武威市住房和城乡建设局网站优化的定义
  • 网站写文案网络营销竞价推广
  • 培训机构网站建设方案怎么制作自己的网站
  • 搭建网站的免费程序曼联vs曼联直播
  • 安徽鲲鹏建设集团有限公司网站seo建设者
  • 网络营销公长沙官网seo技术
  • 微信里面的小程序百度seo点击软件
  • 南京网站建设学习海外推广渠道
  • 怎么建设网站数据库个人网站的制作
  • 做网站要建立站点吗文山seo
  • 西宁高端网站建设站内优化怎么做
  • 宝山北京网站建设推广平台
  • 营销型网站建设实战感想优化电脑的软件有哪些
  • 广州商砼建站规范公众号seo排名软件
  • 网站建设费的摊销年限b站推广网站2024mmm
  • 光谷 网站建设公司搜狗输入法下载安装
  • 网站怎么做图片按按钮跳转广州百度网站推广
  • 做电影网站放抢先版网络推广员每天的工作是什么
  • excel做注册网站媒体发稿费用
  • wordpress 远程网站seo推广公司靠谱吗
  • 找外包公司做网站给源码吗seo关键词排名优化案例
  • 软件网站建设基本流程培训机构排名一览表
  • 建设网站规划书快推广app下载
  • 怎么改网站上的logo技术培训
  • 如何用ps做网站ui怎么制作网站教程
  • 桂林网站建设短信营销
  • 学校建设微网站的方案设计站长工具seo推广 站长工具查询
  • 网店运营入门基础知识专业网站优化外包
  • wordpress 上传漏洞快手seo
  • 沧州网站制作教程百度地图排名可以优化吗