题解 | #JZ72 数字在升序数组中出现的次数#

数字在升序数组中出现的次数

http://www.nowcoder.com/practice/70610bf967994b22bb1c26f9ae901fa2

//二分查找
class Solution {
public:
    int GetNumberOfK(vector<int> data ,int k) {
        int leftBound, rightBound;
        
        //查找下界
        int left = 0, right = data.size();
        while (left < right) {
            int mid = (left + right) / 2;
            if (data[mid] < k) left = mid + 1;
            else right = mid;
        }
        leftBound = left;
        
        //查找上界
        left = 0, right = data.size();
        while (left < right) {
            int mid = (left + right) / 2;
            if (data[mid] <= k) left = mid + 1;
            else right = mid;
        }
        rightBound = right;
        
        return rightBound - leftBound;
    }
};
全部评论

相关推荐

小浪_Coding:找硬件测试,也可兼顾软测欧, 简历还可以的 ,注意排版,项目写的有条理一点, 然后个人技能多加点, 润色好简历之后就开始沟通海投了,深圳,东莞这边做硬件相关的公司还不少, 医疗类,仪器类的都可以尝试
点赞 评论 收藏
分享
05-23 19:02
吉林大学 Java
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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