题目来源于知识星球—英雄算法联盟,五月算法集训专题
目录
前言
跟随英雄算法联盟博主—英雄哪里出来,每天完成相应的算法练习,一个月后,必定会有所成长!
一、35.搜索插入位置(简单)
1.题目描述
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.题目描述
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.题目描述
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.题目描述
2.解题思路
暂时还不会做
3.代码演示(C++)
4.题目链接
总结
每天跟随英雄哥学习相关的算法,一个月会收获很多,如果你想了解更多关于知识星球的内容,欢迎联系我!