Leetcode_34. 在排序数组中查找元素的第一个和最后一个位置
二分查找,lower_bound和upper_bound。
code
class Solution {
public:
vector<int> searchRange(vector<int>& nums, int target) {
int n=nums.size();
int l=0,r=n-1;
vector<int> ans(2,-1);
while(l<=r){
int mid=(l+r);
if(nums[mid]==target){
ans[0]=mid;
r=mid-1;
}else if(nums[mid]<target){
l=mid+1;
}else{
r=mid-1;
}
}
l=0,r=n-1;
while(l<=r){
int mid=(l+r);
if(nums[mid]==target){
ans[1]=mid;
l=mid+1;
}else if(nums[mid]<target){
l=mid+1;
}else{
r=mid-1;
}
}
return ans;
}
};
【推荐】博客园的心动:当一群程序员决定开源共建一个真诚相亲平台
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】Flutter适配HarmonyOS 5知识地图,实战解析+高频避坑指南
【推荐】凌霞软件回馈社区,携手博客园推出1Panel与Halo联合终身会员
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· golang中写个字符串遍历谁不会?且看我如何提升 50 倍
· C# 代码如何影响 CPU 缓存速度?
· 智能桌面机器人:使用 .NET 为树莓派开发 Wifi 配网功能
· C# 模式匹配全解:原理、用法与易错点
· 记一次SSD性能瓶颈排查之路——寿命与性能之间的取舍
· 时隔半年,拾笔分享:来自一个大龄程序员的迷茫自问
· 3 个超火的开源项目「GitHub 热点速览」
· C#-Visual Studio工具使用实践
· [原创]《C#高级GDI+实战:从零开发一个流程图》第02章:画一个矩形,能拖动!
· WineHQ 发布的 Framework Mono 6.14 的这个特性对Windows Form