题解 | #二分#

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

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

相关推荐

10-04 17:25
门头沟学院 Java
snqing:Java已经饱和了,根本不缺人。随便一个2000工资的都200人起投递
点赞 评论 收藏
分享
菜菜咪:1. 可以使用简历网站的模版,美观度会更好一点 2. 邮箱可以重新申请一个,或者用qq邮箱的别名,部分hr可能会不喜欢数字邮箱 3. 项目经历最好分点描述,类似的项目很多,可以参考一下别人怎么写的 4. 自我评价可加可不加,技术岗更看重技术。最后,加油,优秀士兵
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务