L-4: 34--在排序数组中查找元素的第一个和最后一个位置
1.L1-两数之和2.L2-二分查找3.L-3: 35.搜索插入位置4.6 -- 27. 移除元素5.L5-367. 有效的完全平方数6.L4: 69.x的平方根
7.L-4: 34--在排序数组中查找元素的第一个和最后一个位置
8.H-29.H-三数之和10.链表指向问题(pre = cur.next与cur.next = pre)11.Java链表12.力扣T26与T27的区别13.7--26. 删除有序数组中的重复项14.8--283. 移动零15.12--76. 最小覆盖子串16.11--209. 长度最小的子数组17.10--977. 有序数组的平方18.9--844. 比较含退格的字符串19.19.删除链表的倒数第N个结点20.27,移除元素21.459.重复的字符串22.28.KMP算法--leetcode23.13--2. 两数相加给你一个按照非递减顺序排列的整数数组 nums
,和一个目标值 target
。请你找出给定目标值在数组中的开始位置和结束位置。
如果数组中不存在目标值 target
,返回 [-1, -1]
。
你必须设计并实现时间复杂度为 O(log n)
的算法解决此问题。
示例 1:
输入:nums = [5,7,7,8,8,10]
, target = 8
输出:[3,4]
示例 2:
输入:nums = [5,7,7,8,8,10]
, target = 6
输出:[-1,-1]
示例 3:
输入:nums = [], target = 0 输出:[-1,-1]
class Solution { public int[] searchRange(int[] nums, int target) { int first = -1, last = -1; //两次二分查找,分别找第一个和第二个 //思路:找到mid = target之后,然后分两部分直接用mid左右挪,找到第一个位置和最后一个位置 //left和right在下面还需要重新初始化 int left = 0, right = nums.length - 1; while (left <= right){ int mid = (left + right) / 2; if (target < nums[mid]){ right = mid - 1; }else if (target > nums[mid]){ left = mid + 1; }else { //找第一个最左第一个等于target的位置 first = mid; right = mid - 1;//重要,right左移,这句可以实现找到最左边第一次出现的target(先不管半右部分) } } //第二次查找最后一个等于target的位置 //这次需要查找右半部分的,所以 left右移 ;left = mid + 1 left = 0; right = nums.length - 1; while (left <= right){ int mid = (left + right) / 2; if (target < nums[mid]){ right = mid - 1; }else if (target > nums[mid]){ left = mid + 1; }else { //找最右等于target的位置 last = mid; left = mid + 1;//重要,right左移,这句可以实现找到最左边第一次出现的target(先不管半右部分) } } return new int[] {first, last}; } }
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· AI 智能体引爆开源社区「GitHub 热点速览」
· 写一个简单的SQL生成工具
· Manus的开源复刻OpenManus初探