gpt4 book ai didi

algorithm - 为什么这个二进制搜索实现会导致溢出?

转载 作者:塔克拉玛干 更新时间:2023-11-03 05:40:11 25 4
gpt4 key购买 nike

二分查找中的实现

int search(int[] A, int K) {
int l = 0;
int u = A.length - 1;
int m
while ( l <= u ) {
m = (l+u)/2; // why this can cause overflow
...
}
}

正确的方法如下:

m = l + (u -l )/2;

不知道为什么更新后的语句没有溢出问题。根据我的理解,更新后的语句迟早也会出现溢出问题。

最佳答案

原件可能溢出,因为l+u可能大于最大值 int可以处理(例如,如果 lu 都是 INT_MAX 那么它们的总和显然会超过 INT_MAX )。

正确的方法不能溢出,因为u-l显然不会溢出,并且l+(u-l)/2保证是 <=u , 所以也不会溢出。

关于algorithm - 为什么这个二进制搜索实现会导致溢出?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4764806/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com