剑指 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;
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 零经验选手,Compose 一天开发一款小游戏!
· 因为Apifox不支持离线,我果断选择了Apipost!
· 通过 API 将Deepseek响应流式内容输出到前端
2020-03-30 ma'p'ma'p'ma'p