题解 | #二分#

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

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;
    }
};
全部评论

相关推荐

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

创作者周榜

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