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

embedded/2024/11/14 12:40:35/

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

给你一个按照非递减顺序排列的整数数组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]

题解

二分查找

由于数组已经排序,因此整个数组是单调递增的,我们可以利用二分法来加速查找的过程。

考虑target开始和结束位置,其实我们要找的就是数组中「第一个等于 target的位置」(记为 leftIdx)和「第一个大于target的位置减一」(记为rightIdx)。

二分查找中,寻找leftIdx即为在数组中寻找第一个大于等于target于的下标,寻找rightIdx即为在数组中寻找第一个大于target的下标,然后将下标减一。两者的判断条件不同,为了代码的复用,我们定义binarySearch(nums, target, lower)表示在nums数组中二分查找target的位置,如果lowertrue,则查找第一个大于等于target的下标,否则查找第一个大于target的下标。

最后,因为target可能不存在数组中,因此我们需要重新校验我们得到的两个下标leftIdxrightIdx,看是否符合条件,如果符合条件就返回[leftIdx,rightIdx],不符合就返回[−1,−1]

python">from typing import Listclass Solution:# lower标志来决定找的是左侧边界还是右侧边界def binary_search(self, nums: List[int], target: int, lower: bool) -> int:left, right = 0, len(nums) - 1ans = len(nums)while left <= right:mid = (left + right) // 2if nums[mid] > target or (lower and nums[mid] >= target):right = mid - 1ans = midelse:left = mid + 1return ansdef search_range(self, nums: List[int], target: int) -> List[int]:left_idx = self.binary_search(nums, target, True)right_idx = self.binary_search(nums, target, False) - 1if left_idx <= right_idx and right_idx < len(nums) and nums[left_idx] == target and nums[right_idx] == target:return [left_idx, right_idx]else:return [-1, -1]# 示例调用
solution = Solution()
nums = [5, 7, 7, 8, 8, 10]
target = 8
result = solution.search_range(nums, target)
print(result)

输出:

python">[3, 4]

http://www.ppmy.cn/embedded/11809.html

相关文章

open-webui与ollama的部署最后完整之命令

docker run -d --networkhost -v open-webui:/app/backend/data -e HF_ENDPOINThttps://hf-mirror.com -e OLLAMA_BASE_URLhttp://127.0.0.1:11434 --name open-webui --restart always ghcr.io/open-webui/open-webui:main -e HF_ENDPOINThttps://hf-mirror.com 一定要加上&a…

MySQL中的存储过程详解(下篇)

使用语言 MySQL 使用工具 Navicat Premium 16 代码能力快速提升小方法&#xff0c;看完代码自己敲一遍&#xff0c;十分有用 拖动表名到查询文件中就可以直接把名字拉进来中括号&#xff0c;就代表可写可不写 目录 1. 查看存储过程 1.1 查看存储过程的状态 1.1.1 基础…

C#基础|对象属性Property基础使用,业务特性

哈喽,你好,我是雷工。 探究OOP中属性的奥秘 认识类的属性(Property) 01 属性的使用 作用:在面向对象(OOP)中主要用来封装数据。 要求:一般采用Pascal命名法(首字母要大写),数据类型和字段要一致,使用public修饰。 02 属性的定义 C#2.0时代标准属性的基本形式…

JRT1.5发布演示

JRT1.5演示视频 这是一次思想的解放&#xff0c;这是一次自我的挑战&#xff0c;这是一次涅槃重生。信创、安可、Linux、麒麟、UOS、King、PGSQL、ARM、Java围绕在我周围。JRT在DotNetCore的基础上完成了重生。对我而言&#xff0c;它不仅仅是一套框架那么简单&#xff1b;它更…

AAAI-24 | EarnHFT:针对高频交易的分层强化学习(RL)框架 附代码实现

AAAI-24 | EarnHFT:针对高频交易的分层强化学习&#xff08;RL&#xff09;框架 摘要(Abstract):高频交易&#xff08;HFT&#xff09;使用计算机算法在短时间内&#xff08;例如秒级&#xff09;做出交易决策&#xff0c;在加密货币市场&#xff08;例如比特币&#xff09;中…

2233: 【数学】因子游戏

题目描述 桐桐把一个自然数N的正因子个数记为F(N)&#xff0c;例如18的所有正因子为1、2、3、6、9、18&#xff0c;所以F(18)6。现在给出K&#xff0c;桐桐想求出所有满足F(N)K的N中最小的数&#xff0c;你能帮助她吗&#xff1f; 输入 第1行为K&#xff0c;其中0<K<8…

大模型引领未来:探索其在多个领域的深度应用与无限可能【第五章、广告营销与文化娱乐:AI与大模型创造无限可能】

大模型引领未来&#xff1a;探索其在多个领域的深度应用与无限可能【第五章、广告营销与文化娱乐&#xff1a;大模型创造无限可能】 五、广告营销与文化娱乐&#xff1a;大模型创造无限可能1.广告创意与内容生成的自动化2.精准广告投放与营销效果的提升3.文化娱乐产业的创新与丰…

Linux复习提纲2

Linux复习提纲 Linux概述 shell&#xff1a;交互式命令解释程序&#xff1b;用户和内核间交互的桥梁Shell不仅是交互式命令解释程序&#xff0c;还是一种程序设计语言shell是一种命令解释程序&#xff0c;批处理shell是linux的外壳&#xff0c;默认是bash2.1 Linux基础概念 log…