码迷,mamicode.com
首页 > 其他好文 > 详细

lower_bound和upper_bound的实现

时间:2016-08-10 18:57:04      阅读:157      评论:0      收藏:0      [点我收藏+]

标签:

int lowerBound(int* nums, int numsSize, int target) {
    //注意left和right的初始值必须是left = 0, right = numsSzie, 因为返回的位置可能是[0,numsSize]
    int left = 0;
    int right = numsSize;
    int mid;
    while (left < right)
    {
        mid = left + (right - left) / 2;
        if (nums[mid] >= target)
            right = mid;
        else
            left = mid + 1;
    }

    return left;
}

int upperBound(int* nums, int numsSize, int target) {
    int left = 0;
    int right = numsSize;
    int mid;
    while (left < right)
    {
        mid = left + (right - left) / 2;
        if (nums[mid] <= target)
            left = mid + 1;
        else
            right = mid;
    }
    return left;
}

  

lower_bound和upper_bound的实现

标签:

原文地址:http://www.cnblogs.com/lakeone/p/5757609.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!