剑指 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 @ 2022-03-30 10:27  小申同学  阅读(28)  评论(0)    收藏  举报