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

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

示例 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;

    }
复制代码
全部评论

相关推荐

01-15 17:34
保定学院 Java
数学转码崽:学历没优势就得卷项目和实习啊,但是我看了一下你这个项目,什么雪花算法,搜索引擎,Docker,minio这些都属于通用的东西啊,根本不算亮点,没有任何业务相关性。 还有第二个看到统一鉴权,分片上传估计面试官都不想看了。连我一个偶尔刷刷牛客简历的都看多了,面试官估计早都看吐了。。。 秋招结束了,就尽量找找中小厂吧,毕竟你现在转行已经没时间了,高低有一段实习经历
点赞 评论 收藏
分享
01-08 09:40
中南大学 Java
苏苏加油努力:你的女神不回你消息,并且给别的男生发消息 be like
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务