您的位置:首页 > 编程语言

编程珠矶 习题 4.6 利用二分搜索找到一个数在顺序数组里面的下限和上限

2012-07-14 15:41 260 查看
很显然,这道题目用二分搜索去解答,关键是怎么样去找这个上限点和下限点,方法很简单,每次去mid, 如果aa[mid] 比key要大的话,那么mid 是key的一个上限,但不一定是最小上限,同理。。。那么不断二分,不断逼近,最后即可求得解
void search_between(int arr[], int n_size, int *up, int *down,int key)
{
int left = 0;
int right = n_size - 1;

*up = INT_MAX;
*down = INT_MIN;

while(left <= right)
{
int mid = (left + right)>>1;
if(arr[mid] < key)
{
*down = mid;
left = mid + 1;
}
else {
*up = mid;
right = mid - 1;
}
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐