[编程题]二分查找

二分查找

http://www.nowcoder.com/questionTerminal/7bc4a1c7c371425d9faa9d1b511fe193

注意

不会输出0,该题的“位置”是从1开始计数的

核心思路

始终维护答案在左闭右闭的 [l, r] 区间内

编码思路:

  1. 为了方便访问 vector ,先不考虑从 1 开始计数的的问题,假设答案的范围是 [0, n](实际输出的就是 [1, n+1] )
  2. 保持 [l, r] 是答案所在的区间,终止条件即 l == r
  3. 每次检验 a[mid] 与查找值 v 的关系来进一步确定答案所在的区间
  4. 如果 a[mid] < v ,答案一定在 [mid+1, r] 区间,否则答案一定在 [l, mid] 区间
class Solution {
public:
    /**
     * 二分查找
     * @param n int整型 数组长度
     * @param v int整型 查找值
     * @param a int整型vector 有序数组
     * @return int整型
     */
    int upper_bound_(int n, int v, vector<int>& a) {
        int l = 0, r = n;
        while(l < r){    //    2. 保持 [l, r] 是答案所在的区间,终止条件即 l == r
            int mid = (l + r) / 2;    //    3. 每次检验 a[mid] 与查找值 v 的关系来进一步确定答案所在的区间
            if(a[mid] < v){    //    4.  如果 a[mid] < v ,答案一定在 [mid+1, r] 区间,否则答案一定在 [l, mid] 区间
                l = mid + 1;
            }
            else{
                r = mid;
            }
        }
        return l + 1;    // 1. 为了方便访问vector,先不考虑从1开始计数的的问题,假设答案的范围是 [0, n](实际输出的是 [1, n+1] )
    }
};
全部评论

相关推荐

12-13 14:51
已编辑
井冈山大学 算法工程师
龙虾x:算法比你强的没有你美,比你美的…..算了已经没有比你美的了
工作两年想退休了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务