题解 | #二分#

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

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

二分

class Solution {
public:
    int GetNumberOfK(vector<int> data ,int k) {
        int n = data.size();
        if(n == 0) return 0;
        int left = 0, right = n - 1;
        int start = lower_bound(data.begin(), data.end(), k) - data.begin();
        if(data[start] != k) return 0;
        int end = lower_bound(data.begin(), data.end(), k + 1) - data.begin();
        //cout << start << " " << end;
        return end - start;
    }
};
class Solution {
public:
    int helper(vector<int> data, int target){
        int n = data.size();
        int left = 0, right = n - 1;
        while(left < right){
            int mid = left + (right - left) / 2;
            if(data[mid] >= target) right = mid;
            else left = mid + 1;
        }
        return left;
    }
    int GetNumberOfK(vector<int> data ,int k) {
        int n = data.size();
        if(n == 0) return 0;
        int left = 0, right = n - 1;
        int start = helper(data, k);
        if(data[start] != k) return 0;
        int end = helper(data, k + 1);
        if(data[end] == k) end ++;
        return end - start;
    }
};
全部评论

相关推荐

05-12 17:00
门头沟学院 Java
king122:你的项目描述至少要分点呀,要实习的话,你的描述可以使用什么技术,实现了什么难点,达成了哪些数字指标,这个数字指标尽量是真实的,这样面试应该会多很多,就这样自己包装一下,包装不好可以找我,我有几个大厂最近做过的实习项目也可以包装一下
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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