数组中查找数字出现的次数(二分法)

统计一个数字在排序数组中出现的次数。

示例 1:

输入: nums = [5,7,7,8,8,10], target = 8 输出: 2

 // 左边界
    public static int searchLeft(int[] arr,int k){
        int l = 0;
        int r = arr.length-1;
        while (l<r){
            int mid = (l+r)>>1;
            if(arr[mid] == k){
                r = mid;
            }else if(arr[mid]>k){
                r = mid-1;
            }else {
                l = mid+1;
            }
        }
        return r;

    }
    // 右边界
    public static int searchRight(int[] arr,int k){
        int l = 0;
        int r = arr.length-1;
        while (l<r){
            // 每次计算取前一位整,这里加一取后一位,避免死循环
            int mid = (l+r+1)>>1;
            if(arr[mid] == k){
                l = mid;
            }else if(arr[mid]>k){
                r = mid-1;
            }else {
                l = mid+1;
            }
        }
        return l;

    }
复制代码
全部评论

相关推荐

10-22 15:25
门头沟学院 C++
种花网友小松:求求你别发了,我几乎都快嫉妒得疯了,倒在床上蒙住被子就开始抱着枕头尖叫流泪,嘴里一边喊着卧槽卧槽,一边又忍着,我边发边哭,打字的手都是抖的,后来我的手抖得越来越厉害,从心头涌起的思想、情怀和梦想,这份歆羡和悔恨交织在一起,我的笑还挂在脸上,可是眼泪一下子就掉下来了。求你了别发了,我生活再难再穷我都不会觉得难过,只有你们发这种东西的时候,我的心里像被刀割一样的痛,打着字泪水就忍不住的往下流。
我的求职进度条
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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