int middle = left + ((right - left) / 2);有防溢出作用?为什么啊啊啊啊?

int middle = left + ((right - left) / 2);

这行代码使用了一些技巧来防止整数溢出:

  1. 将 (right - left) 括号起来,确保先进行减法运算。这可以防止如果先加 left 可能引起的溢出。

  2. 使用除法运算 (right - left) / 2 而不是乘法来计算中间索引。乘法更容易导致溢出。

  3. 使用左移右移位运算更安全,但除法运算更简洁。

  4. 强制类型转换为 int 可以截断任何可能的溢出位。

  5. left 和 right 作为参数传入,保证它们在 int 范围内。

  6. 中间索引一定在 left 和 right 之间,所以不太可能溢出 int 范围。

  7. 用一个表达式计算中间索引而不是分步计算,可以最小化溢出的机会。

所以这种计算中间索引的技巧可以很好地防止整数溢出的风险。主要原因是使用了除法而不是乘法,并且进行了合理的约束和类型转换。这在二分查找算法中计算中间索引时是一个常见且安全的做法。

平时我们应该如何怎么使用乘法来计算中间索引呢?

使用乘法来计算二分查找算法的中间索引的方法:

  1. 不使用除法,直接用乘法计算:

    mid = left + (right - left) * 0.5

这里使用0.5而不是1/2来避免整形除法的截断错误。

  1. 可以使用位移运算符代替乘法,效率更高:

    mid = (left + right) >> 1

右移一位相当于除以2。

  1. 如果左右索引非常大,可以分两步计算:

    diff = right - left
    mid = left + (diff >> 1)

防止一次计算中间索引时溢出。

  1. 还可以使用一些数学技巧:

    mid = (left + right) / 2
    mid = left + (right - left) / (1 << 1)

使用位运算和分步计算来避免溢出。

  1. 如果每次比较时调整左右索引,也可以不 explicitly 计算 mid:

    if(arr[mid] > target) right = mid;
    else left = mid;

综上,使用乘法计算中间索引可以避免除法的截断错误,但需要注意溢出问题。位运算和分步计算可以很好地防止溢出。需根据具体情况选择最优方法。

  • 9
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

白小白的学习笔记

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值