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

明年做那个网站能致富怎么做seo

明年做那个网站能致富,怎么做seo,做美容行业的网站哪个好,做jsp网站用哪些软件内容介绍 给你两个整数,被除数 dividend 和除数 divisor。将两数相除,要求 不使用 乘法、除法和取余运算。 整数除法应该向零截断,也就是截去(truncate)其小数部分。例如,8.345 将被截断为 8 ,-…

内容介绍

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

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

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

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

示例 1:

输入: dividend = 10, divisor = 3
输出: 3
解释: 10/3 = 3.33333.. ,向零截断后得到 3 。

示例 2:

输入: dividend = 7, divisor = -3
输出: -2
解释: 7/-3 = -2.33333.. ,向零截断后得到 -2 。

提示:

  • -231 <= dividend, divisor <= 231 - 1
  • divisor != 0

完整代码

 class Solution {public int divide(int dividend, int divisor) {if (dividend == Integer.MIN_VALUE) {if (divisor == 1) {return Integer.MIN_VALUE;}if (divisor == -1) {return Integer.MAX_VALUE;}}if (divisor == Integer.MIN_VALUE) {return dividend == Integer.MIN_VALUE ? 1 : 0;}if (dividend == 0) {return 0;}boolean rev = false;if (dividend > 0) {dividend = -dividend;rev = !rev;}if (divisor > 0) {divisor = -divisor;rev = !rev;}int left = 1, right = Integer.MAX_VALUE, ans = 0;while (left <= right) {int mid = left + ((right - left) >> 1);boolean check = quickAdd(divisor, mid, dividend);if (check) {ans = mid;if (mid == Integer.MAX_VALUE) {break;}left = mid + 1;} else {right = mid - 1;}}return rev ? -ans : ans;}public boolean quickAdd(int y, int z, int x) {int result = 0, add = y;while (z != 0) {if ((z & 1) != 0) {if (result < x - add) {return false;}result += add;}if (z != 1) {if (add < x - add) {return false;}add += add;}z >>= 1;}return true;}
}

思路详解

整体思路

该代码实现了一个整数除法功能,主要解决以下问题:

  1. 处理特殊边界情况,如被除数或除数为整数最小值。
  2. 处理除数为0的情况。
  3. 通过二分查找确定商的大小。
  4. 使用快速乘法判断二分查找中的中间值是否满足条件。

详细步骤

  1. 处理特殊边界情况

    • 当被除数为Integer.MIN_VALUE时,需要单独处理除数为1和-1的情况,因为直接计算会导致溢出。
    • 当除数为Integer.MIN_VALUE时,只有当被除数也是Integer.MIN_VALUE时,商为1,否则为0。
  2. 处理除数为0的情况

    • 当被除数为0时,直接返回0。
  3. 统一处理负数

    • 将被除数和除数都转换为负数,这样只需考虑一种情况。同时记录转换次数,最后根据转换次数确定返回值的正负。
  4. 二分查找确定商的大小

    • 初始化左边界为1,右边界为Integer.MAX_VALUE
    • 在二分查找过程中,计算中间值mid,并使用快速乘法判断mid * divisor是否大于等于dividend
    • 如果满足条件,更新答案ans,并将左边界更新为mid + 1;否则,将右边界更新为mid - 1
  5. 快速乘法

    • 由于不能使用除法,使用快速乘法来判断mid * divisor是否大于等于dividend
    • 通过位运算和加法模拟乘法操作,同时避免溢出。

代码注释说明

  • rev:记录被除数和除数转换为负数的次数,用于最后确定返回值的正负。
  • quickAdd:快速乘法函数,用于判断y * z是否大于等于x
  • leftrightans:二分查找的左边界、右边界和当前答案。
  • mid:二分查找的中间值。
  • check:用于判断mid * divisor是否大于等于dividend

知识点精炼

特殊情况处理

  1. 整数最小值:处理Integer.MIN_VALUE作为被除数或除数的情况,防止溢出。
  2. 除数为0:明确除数为0时,结果为0。

负数统一处理

  1. 符号转换:将被除数和除数统一转换为负数,简化问题处理。
  2. 符号记录:使用布尔变量记录被除数和除数的符号转换次数,以确定最终结果的符号。

二分查找

  1. 查找范围:初始化左边界为1,右边界为Integer.MAX_VALUE
  2. 中间值计算:使用位运算计算中间值,避免溢出。
  3. 条件判断:通过快速乘法判断中间值是否满足条件。

快速乘法

  1. 位运算:利用位运算模拟乘法操作,避免直接使用乘法导致溢出。
  2. 加法替代:通过加法累加结果,判断是否满足条件。

防溢出

  1. 边界检查:在计算过程中,确保不发生溢出。
  2. 无除法:全程不使用除法操作,避免因除法导致的精度问题。

 

http://www.rdtb.cn/news/15196.html

相关文章:

  • 网站开发一般会使用框架吗广州网站设计制作
  • 有没有电脑做兼职的网站营销网络怎么写
  • 个人网站建设服务网站设计方案模板
  • 深圳高端网站建设创新seo查询外链
  • 做网站的专业公司关键词优化哪个好
  • 门户网站有哪些推广分类seo 重庆
  • 有做装修效果图赚钱的网站吗seo教程最新
  • 网站建设 收费明细海淀区seo搜索引擎
  • 做网站v1认证是什么意思品牌营销推广策划方案
  • 做美食分享网站源码电商平台营销策划方案
  • 网站开发公司的职责重大军事新闻最新消息
  • 松原市住房和城乡建设局网站seo技术服务外包公司
  • 网站建设 协议书谷歌广告上海有限公司官网
  • 优秀网页设计排版惠州seo报价
  • 男直接做的视频网站个人在百度上发广告怎么发
  • 阿里巴巴网站威海哪里做?百度手游app下载
  • 咸宁网站建设百度网首页
  • 怎么做网站账号注册机销售推广的方法都有哪些
  • wordpress keywordseo经验
  • 保险理财网站建设网页制作代码模板
  • 网站建设金手指稳定网站推广多少钱一年
  • 网站建设写程序用什么软件怎么下载需要会员的网站视频
  • 成都高度网站技术建设公司企业网络营销策略案例
  • 招商网站建设大概多少钱太原做网站的
  • 国外有建站公司吗搜索seo是什么意思
  • 能看外国网站的浏览器一站式发稿平台
  • ip开源网站fpga可以做点什么用媒体软文发稿
  • 网站通常用什么编程做接广告的平台
  • php网站后台无法上传图片百度网盘服务电话6988
  • 越秀手机网站建设苏州疫情最新情况