每天一道leetcode:剑指 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 <= 10^5

  • -10^9 <= nums[i] <= 10^9

  • nums 是一个非递减数组

  • -10^9 <= target <= 10^9

题目思路

使用两次二分查找找到target在数组中的左右边界,然后长度就是右边界减去左边界再加一,最后返回长度即可。

代码

cpp 复制代码
class Solution 
{
public:
    int binarySearch(vector<int>& nums, int target, bool lower) 
    {//二分查找,lower为true表示查找第一个大于等于target的下标(左端点),为false表示查找第一个大于target的下标(右端点)
        int left=0,right=nums.size()-1,ans=nums.size();
        while(left<=right) 
        {
            int mid=(left+right)/2;
            if(nums[mid]>target||(lower&&nums[mid]>=target)) 
            {//需要移到左半部分继续二分查找
                right=mid-1;
                ans=mid;
            } 
            else //需要移到右半部分继续二分查找
            {
                left=mid+1;
            }
        }
        return ans;
    }

    int search(vector<int>& nums, int target) 
    {
        int l=binarySearch(nums,target,true);//二分查找左端点
        int r=binarySearch(nums,target,false)-1;//二分查找右端点
        if(l<=r&&r<nums.size()&&nums[l]==target&&nums[r]==target) 
        {//如果存在这样的全是target这个数的区间,并且未超出nums范围,并且确定区间内的数都是target
            return r-l+1;
        }
        return 0;//不符合返回0
    }
};

提交结果

欢迎大家在评论区讨论,如有不懂的代码部分,欢迎在评论区留言!

相关推荐
老赵聊算法、大模型备案2 小时前
北京市生成式人工智能服务已备案信息公告(2025年12月11日)
人工智能·算法·安全·aigc
CoderYanger3 小时前
C.滑动窗口-求子数组个数-越长越合法——2799. 统计完全子数组的数目
java·c语言·开发语言·数据结构·算法·leetcode·职场和发展
厕所博士3 小时前
红黑树原理前置理解—— 2-3 树
算法·2-3树·红黑树原理理解前置
萌>__<新3 小时前
力扣打卡每日一题————除自身外所有元素的乘积
数据结构·算法
xu_yule4 小时前
算法基础—搜索(2)【记忆化搜索+BFS+01BFS+Floodfill]
数据结构·算法
s09071364 小时前
Xilinx FPGA使用 FIR IP 核做匹配滤波时如何减少DSP使用量
算法·fpga开发·xilinx·ip core·fir滤波
老马啸西风4 小时前
成熟企业级技术平台-10-跳板机 / 堡垒机(Bastion Host)详解
人工智能·深度学习·算法·职场和发展
子夜江寒4 小时前
逻辑回归简介
算法·机器学习·逻辑回归
软件算法开发4 小时前
基于ACO蚁群优化算法的多车辆含时间窗VRPTW问题求解matlab仿真
算法·matlab·aco·vrptw·蚁群优化·多车辆·时间窗
another heaven4 小时前
【软考 磁盘磁道访问时间】总容量等相关案例题型
linux·网络·算法·磁盘·磁道