【刷爆LeetCode】五月算法集训(9)二分查找

本文介绍了四个算法问题,包括35.搜索插入位置、704.二分查找、剑指Offer53-1.在排序数组中查找数字I以及911.在线选举。通过C++代码展示了二分查找在不同场景的应用,如搜索插入位置、查找特定数字出现次数。同时,对于在线选举问题,提出了后续学习的需求。
摘要由CSDN通过智能技术生成

题目来源于知识星球—英雄算法联盟,五月算法集训专题

前言

跟随英雄算法联盟博主—英雄哪里出来,每天完成相应的算法练习,一个月后,必定会有所成长!


一、35.搜索插入位置(简单)

1.题目描述

https://img-blog.csdnimg.cn/9228089a7fce408c9bef9d20774f271b.jpeg =500x

2.解题思路

二分查找的思路就是每次查找都是先找到中间值,然后中间值与目标值进行比较,
如果中间值小与目标值,则目标值在右半部分,那么将左边界设置为中间位置+1;
相反,如果中间值大于目标值,则目标值在左半部分,那么将将右边界设置为中
间位置-1。

3.代码演示(C++)

class Solution 
{
public:
    int searchInsert(vector<int>& nums, int target) 
    {
        int n=nums.size();
        int l=0;
        int r=n-1;
        int ans=n;//结果初始化为数组长度,目标值不存在时,放到最后一个位置
        while(l<=r)
        {
            int mid=(l+r)/2;
            if(nums[mid]>=target)
            {
                ans=mid;
                r=mid-1;//寻找大于等于目标值的最小下标,并向左更新
            }
            else 
            {
                l=mid+1;
            }
        }
        return ans;

    }
};

4.题目链接

题目传送门


二、704.二分查找(简单)

1.题目描述

https://img-blog.csdnimg.cn/2d4646142b14485bbfd589dec0946081.jpeg =500x

2.解题思路

此题与第一题思路相同,在进行查找之后,用ans来存储大于等于target的最小
下标,如果ans等于右边界或对应数组值不等于target,返回-1.

3.代码演示(C++)

class Solution 
{
public:
    int search(vector<int>& nums, int target) 
    {
        int n=nums.size();
        int l=0;
        int r=n-1;
        int ans=n;
        while(l<=r)
        {
            int mid=(l+r)/2;
            if(nums[mid]>=target)
            {
                ans=mid;
                r=mid-1;
            }
            else
            {
                l=mid+1;
            }
           
        }//用ans来存储大于等于targrt的最小下标
        if(ans==n||nums[ans]!=target)
        {//如果ans等于右边界或对应的数组值不等于target,返回-1
            return -1;
        }
        else 
        {
            return ans;
        }

    }
};

4.题目链接

题目传送门


三、剑指 Offer 53-1.在排序数组中查找数字I(简单)

1.题目描述

https://img-blog.csdnimg.cn/43544a780b9f4ca1b4642362deeb23da.jpeg =500x

2.解题思路

遍历数组,当数组中的某个值等于目标值时,计数器++

3.代码演示(C++)

class Solution 
{
public:
    int search(vector<int>& nums, int target) 
    {
        int n=nums.size();
        int ans=0;
        for(int i=0;i<n;i++)
        {
            if(nums[i]==target)
            {
                ans++;
            }
        }
        return ans;

    }
};

4.题目链接

题目传送门


四、911.在线选举(中等)

1.题目描述

https://img-blog.csdnimg.cn/173198a222ce48e0aa327999697ed022.jpeg =500x

2.解题思路

暂时还不会做

3.代码演示(C++)


4.题目链接

题目传送门


总结

每天跟随英雄哥学习相关的算法,一个月会收获很多,如果你想了解更多关于知识星球的内容,欢迎联系我!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值