博客园主题Bili2.0发布啦,快来看看(点击查看)

剑指 Offer 53 - I. 在排序数组中查找数字 I

剑指 Offer 53 - I. 在排序数组中查找数字 I

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

示例 1:

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

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

提示:

0 <= nums.length <= 105
-109 <= nums[i] <= 109
nums 是一个非递减数组
-109 <= target <= 109

复制代码
class Solution {
    public int search(int[] nums, int target) {

            if(nums.length==0)return 0;
            if(nums.length==1&&nums[0]==target)return 1;
            else if(nums.length==1&&nums[0]!=target) return 0;

            int l = 0,r =nums.length-1;

            while(l<r)
            {
                int mid = (l+r)>>1;
                if(nums[mid]>=target) // [l,mid-1][mid,r]
                r = mid;  //左边界 mid在左 右边界mid在右 相反r =mid
                else
                {
                    l = mid+1;
                }
            }
            int cnt = 0;
            for(int i  = l ;i<nums.length;i++)
            {
                if(nums[i]==target)cnt++;
                else break;
            }
            return cnt;

    }
}
posted @   小申同学  阅读(20)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
历史上的今天:
2020-03-30 ma'p'ma'p'ma'p
点击右上角即可分享
微信分享提示