LeetCode如何解决在排序数组中查找元素的第一个和最后一个位置问题
发表于:2025-12-04 作者:千家信息网编辑
千家信息网最后更新 2025年12月04日,这篇文章将为大家详细讲解有关LeetCode如何解决在排序数组中查找元素的第一个和最后一个位置问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。题目描述给定一个按照
千家信息网最后更新 2025年12月04日LeetCode如何解决在排序数组中查找元素的第一个和最后一个位置问题
这篇文章将为大家详细讲解有关LeetCode如何解决在排序数组中查找元素的第一个和最后一个位置问题,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
题目描述
给定一个按照升序排列的整数数组 nums,和一个目标值 target。找出给定目标值在数组中的开始位置和结束位置。
你的算法时间复杂度必须是 O(log n) 级别。
如果数组中不存在目标值,返回 [-1, -1]。
示例:
输入: nums = [5,7,7,8,8,10], target = 8输出: [3,4]
输入: nums = [5,7,7,8,8,10], target = 6输出: [-1,-1]
题目解析
题目中要求了时间复杂度为O(log n),这就很清楚要使用二分查找法了。
首先定义两个指针变量,分别存储左右两个位置的索引。首先去找目标值的最左面的索引,通过循环为了防止元素丢失,每次保留最右面的元素,左侧的指针移动时+1。在循环结束的时候判断一下数组中是否包括目标值,不包括的话直接退出。右面的跟左侧相同,只不过正好相反。
代码实现
// 34. 下一个排列// https://leetcode-cn.com/problems/find-first-and-last-position-of-element-in-sorted-array/// 时间复杂度:O(n)// 空间复杂度:O(1)class Solution {public int[] searchRange(int[] nums, int target) {int[] res = new int[] { -1, -1 };int left = 0;int right = nums.length - 1;int l = left;int r = right;while (left < right) {int mid = (left + right) / 2;if (nums[mid] < target) {left = mid + 1;} else {right = mid;}}if (left>right||nums[left]!=target) {return new int[]{-1,-1};}while (l < r) {int mid = (l + r) / 2 + 1;if (nums[mid] > target) {r = mid - 1;} else {l = mid;}}if (left > right || left > r) {return new int[] { -1, -1 };} else {return new int[] { left, r };}}}
关于"LeetCode如何解决在排序数组中查找元素的第一个和最后一个位置问题"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
数组
位置
目标
目标值
元素
复杂
复杂度
时间
篇文章
面的
题目
问题
排序
两个
指针
更多
索引
循环
输入
输出
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
去美国找软件开发工作
怎么管理服务器存储空间不足
信息网络安全主题党日
万方数据库万方医学区别
数据库架构的作用
打开数据库连接下列语句正确的是
工行软件开发中心每年调薪
信息化技术和网络安全的关系
健康软件开发成本
line服务器连接失败
关于互联网的科技词语
sql数据库管理教学
开票软件数据库文件
魔兽服务器奎尔塞拉
go语言连接国产数据库
软件开发有限公司税务筹划方案
数据库数据加密技术
干休所抓网络安全
网络安全藏文内容
校园网络安全技术与策略
上海云舞科技网络技术有限公司
vfp数据库案例
深圳软件开发厂家
管理服务器
国家网络安全法报道
软件开发各阶段时间
餐饮软件开发协议
腾讯云企业网站服务器配置
数据库中事务的控制
立交桥数据库2