news 2026/5/8 19:32:27

在排序数组中查找元素的第一个和最后一个位置

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
在排序数组中查找元素的第一个和最后一个位置

题目描述

给你一个按照非递减顺序排列的整数数组nums,和一个目标值target。请你找出给定目标值在数组中的开始位置和结束位置。

如果数组中不存在目标值target,返回[-1, -1]

你必须设计并实现时间复杂度为O(log n)的算法解决此问题。

解题思路:

class Solution { public int[] searchRange(int[] nums, int target) { int[] res = new int[]{-1,-1}; int left = 0; int right = nums.length-1; while(left <= right){ int temp = (left + right) >> 1; if(nums[temp] > target){ right = temp - 1; }else if(nums[temp] < target){ left = temp + 1; }else{ left = temp; right = temp; while((right <nums.length-1)&&(nums[right] == nums[right+1])){ right++; } while((left > 0)&&(nums[left] == nums[left-1])){ left--; } res[0] = left; res[1] = right; } } return res; } }

这是最朴素的思想,二分查找,如果找到了再往两边拓展,处理边界条件,只可惜超时了。

需要对二分法再进行二分查找。

官方题解:

class Solution { public int[] searchRange(int[] nums, int target) { int leftIdx = binarySearch(nums, target, true); int rightIdx = binarySearch(nums, target, false) - 1; if (leftIdx <= rightIdx && rightIdx < nums.length && nums[leftIdx] == target && nums[rightIdx] == target) { return new int[]{leftIdx, rightIdx}; } return new int[]{-1, -1}; } public int binarySearch(int[] nums, int target, boolean lower) { int left = 0, right = nums.length - 1, ans = nums.length; while (left <= right) { int mid = (left + right) / 2; if (nums[mid] > target || (lower && nums[mid] >= target)) { right = mid - 1; ans = mid; } else { left = mid + 1; } } return ans; } }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/2 20:02:30

小红书直播永久录制方案:告别频繁更新链接的烦恼

小红书直播永久录制方案&#xff1a;告别频繁更新链接的烦恼 【免费下载链接】DouyinLiveRecorder 项目地址: https://gitcode.com/gh_mirrors/do/DouyinLiveRecorder 你是不是也有过这样的经历&#xff1f;好不容易找到喜欢的小红书主播&#xff0c;刚准备录制直播&am…

作者头像 李华
网站建设 2026/5/7 11:02:33

4、Linux 编程中的错误处理与输入输出操作

Linux 编程中的错误处理与输入输出操作 在 Linux 编程中,错误处理和输入输出操作是非常重要的部分。下面将详细介绍常见的错误代码及其描述,以及 Linux 中文件的输入输出方法。 1. Linux API 错误代码及描述 Linux API 中有许多不同的错误代码,每个代码都对应着特定的错误…

作者头像 李华
网站建设 2026/5/8 11:49:50

11、深入理解进程间通信(IPC)及相关API

深入理解进程间通信(IPC)及相关API 1. 进程间通信基础 在Linux系统中,消息队列、信号量和共享内存等资源存储于内核中,可被多个进程访问。为了唯一标识这些IPC资源,进程需要使用IPC键,这是一个整数标识符。当使用 msgget 、 shmget 或 semget 等函数创建IPC资源时…

作者头像 李华
网站建设 2026/5/3 11:15:14

19、Python 文件处理与数据同步实用技巧

Python 文件处理与数据同步实用技巧 1. 目录差异比较 在处理文件和目录时,经常需要找出两个目录之间的差异。我们可以使用 Python 的 os 模块来实现这一功能。以下是一个示例代码: import osdirA = set(os.listdir("/tmp/dirA")) print(dirA) # 输出: set([…

作者头像 李华