当前位置: 首页 > article >正文

【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]二、解题思路题目明确要求时间复杂度为O(log n)暴力遍历O(n)不符合要求必须使用二分查找。核心需求拆解找到目标值的左边界第一个等于target的位置和右边界最后一个等于target的位置。优化思路复用同一个“找下界”的二分函数避免写两套逻辑1. 左边界直接调用lowBound(nums, target)得到第一个大于等于target的索引2. 右边界调用lowBound(nums, target 1)得到第一个大于等于target1的索引再减1即为最后一个等于target的索引3. 先判断左边界是否有效是否存在target不存在则直接返回[-1,-1]。三、代码实现Javaclass Solution {public int[] searchRange(int[] nums, int target) {// 1. 找目标值的左边界第一个等于target的位置int start lowBound(nums, target);// 2. 判断目标值是否存在左边界超出数组或对应元素不等于target说明不存在if (start nums.length || nums[start] ! target) {return new int[]{-1, -1};}// 3. 找右边界找target1的下界再减1即为最后一个等于target的位置int end lowBound(nums, target 1) - 1;return new int[]{start, end};}/*** 找数组中第一个大于等于target的元素的索引下界函数* param nums 非递减排序数组* param target 目标值* return 第一个大于等于target的索引不存在则返回nums.length*/public int lowBound(int[] nums, int target) {int left 0;int right nums.length - 1;int mid 0;// 闭区间二分查找保证遍历所有元素while (left right) {// 计算中间位置避免low high直接相加导致int溢出mid left (right - left) / 2;if (nums[mid] target) {// mid值大于等于target左边界在左侧含mid更新右边界right mid - 1;} else {// mid值小于target左边界在右侧不含mid更新左边界left mid 1;}}// 循环结束时left即为第一个大于等于target的位置return left;}}四、核心笔记 易错点解析1. 二分查找中“等于”情况的合并逻辑- 正常二分查找中若nums[mid] target需要向左查找right mid - 1- 在找下界第一个大于等于target的位置时nums[mid] target也需要向左查找因为左侧可能存在更小的索引等于target因此将与的情况合并处理统一更新right mid - 1- 若要找上界最后一个等于target的位置则nums[mid] target需要向右查找此时应与的情况合并更新left mid 1- 无需死记硬背“等于和谁合并”只需根据找上下界的需求确定时该往哪个方向缩小区间再合并即可。2. 目标值不存在的三种情况分析调用lowBound函数后若目标值不在数组中会出现三种情况- 数组所有元素都小于target此时left nums.length超出数组范围right nums.length - 1需通过start nums.length判断不存在- 数组所有元素都大于target此时left 0但nums[left] ! target需通过nums[start] ! target判断不存在- 数组中部分元素小于target、部分大于target此时right是小于target的最大值的索引left是大于target的最小值的索引同样通过nums[start] ! target判断不存在因此调用lowBound后必须加上start nums.length || nums[start] ! target的判断才能确定target是否存在。3. 循环结束的边界特性由于while (left right)的循环条件无论与谁合并在一起循环结束时一定满足right left且right 1 left- 若target存在于数组中left是目标值的下界right是小于target的最大元素的索引- 若target不存在left是target应该插入的位置right是小于target的最大元素的索引这个特性是后续计算右边界lowBound(nums, target 1) - 1的核心依据。五、复杂度分析-时间复杂度O(log n)两次调用lowBound函数每次都是二分查找时间复杂度为O(log n)两次调用仍为O(log n)符合题目要求。-空间复杂度O(1)仅使用了常数级别的额外变量没有使用额外的辅助空间。六、总结- 这道题的核心是利用“找下界”的二分函数同时解决目标值左右边界的查找问题避免了写两套二分逻辑代码更简洁易维护。- 关键在于理解二分查找中情况的合并逻辑以及循环结束后left和right的边界特性。- 必须先判断目标值是否存在再计算右边界避免数组越界或返回错误结果。

相关文章:

【LeetCode 刷题笔记】34. 在排序数组中查找元素的第一个和最后一个位置 | 二分查找经典刷题题解

一、题目描述 给你一个按照非递减顺序排列的整数数组 nums,和一个目标值 target。请你找出给定目标值在数组中的开始位置和结束位置。 如果数组中不存在目标值 target,返回 [-1, -1]。 你必须设计并实现时间复杂度为 O(log n) 的算法解决此问题。 示例 1…...

基于Claude API的智能体服务器框架:工程化AI应用开发实践

1. 项目概述与核心价值最近在探索AI应用落地的过程中,我发现了一个非常有意思的项目:MohamedOsamaHelmyCS/claude-agent-server。乍一看这个标题,你可能会觉得这又是一个围绕某个特定AI模型构建的“玩具”项目,但深入研究后&#…...

FreeRTOS菜鸟入门(二十)·ARM架构简介

目录 1. 前提 2. ARM架构 3. ARM 汇编指令 3.1 LDR(Load Register):读内存 3.2 STR(Store Register):写内存 3.3 ADD(加法) 3.4 SUB(减法) 3…...

冒险岛游戏资源终极定制指南:使用Harepacker-resurrected打造个性化游戏体验

冒险岛游戏资源终极定制指南:使用Harepacker-resurrected打造个性化游戏体验 【免费下载链接】Harepacker-resurrected All in one .wz file/map editor for MapleStory game files 项目地址: https://gitcode.com/gh_mirrors/ha/Harepacker-resurrected 你是…...

如何用Dell Fans Controller实现戴尔服务器风扇静音控制?5个实用技巧

如何用Dell Fans Controller实现戴尔服务器风扇静音控制?5个实用技巧 【免费下载链接】dell_fans_controller A tool for control the Dell server fans speed, it sends the control instruction by ipmitool over LAN for Windows, it is a GUI application which…...

开源运维平台OpenClaw-Ops:从GitOps到可观测性的实践指南

1. 项目概述:一个开源运维平台的诞生与价值在当今的软件开发和部署环境中,运维工作早已不是简单的“看管服务器”。随着微服务、容器化和云原生技术的普及,一个应用背后可能是成百上千个服务实例、复杂的网络拓扑和动态变化的资源需求。对于任…...

收藏!2026 年版:未来 10 年,职业发展潜力最大的领域(小白 程序员必看)

答案永远只有一个:人工智能(大模型方向)。2026年的职场,早已进入“冰火两重天”的分化模式。一边是传统开发岗内卷到极致,投出上百份简历大多石沉大海,35岁职业焦虑持续蔓延;另一边是AI大模型人…...

Docker Compose与Nginx构建一体化Web开发环境实战指南

1. 项目概述与核心价值 最近在折腾一个挺有意思的项目,叫“SmokeAlot420/ftw”。乍一看这个名字,可能有点摸不着头脑,甚至带点调侃的意味。但如果你深入了解一下,会发现这其实是一个在特定开发者圈子里流传的、用于快速搭建和测试…...

江苏电子式动态平衡电动调节阀推荐

在江苏的工业生产、建筑暖通等众多领域,电子式动态平衡电动调节阀的应用极为广泛。它对于保障系统的稳定运行、实现节能降耗起着关键作用。今天,就为大家推荐一家在这方面表现出色的企业——天津水阀机械有限公司。一、企业实力有目共睹天津水阀机械有限…...

【多无人机动态避障路径规划】基于蚂蚁狮子优化算法的多无人机三维协同路径规划方法(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...

创业团队如何利用Taotoken低成本快速验证多个AI产品创意

创业团队如何利用Taotoken低成本快速验证多个AI产品创意 1. 统一接入降低开发成本 对于资源有限的创业团队,快速验证多个AI产品创意的首要挑战是技术集成成本。传统模式下,团队需要为每个主流模型单独注册账号、申请API Key、学习不同厂商的接入规范&a…...

Happy Island Designer终极指南:5步打造你的梦想岛屿规划

Happy Island Designer终极指南:5步打造你的梦想岛屿规划 【免费下载链接】HappyIslandDesigner "Happy Island Designer (Alpha)",是一个在线工具,它允许用户设计和定制自己的岛屿。这个工具是受游戏《动物森友会》(Animal Crossi…...

通过动态规划优化插电式混合动力电动汽车 (PHEV) 能源管理(Matlab、Simulink代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...

深入解析Auto-Code-Executor:声明式任务编排框架的设计与实战

1. 项目概述与核心价值最近在GitHub上看到一个挺有意思的项目,叫NeoSkillFactory/auto-code-executor。光看名字,你可能会觉得这又是一个“自动执行代码”的工具,市面上类似的脚本或者库好像也不少。但当我真正深入去研究它的源码和应用场景后…...

从原子性到串行化:数据库事务全解

目录 ​编辑 一、前言 二、什么是事务 三、为什么会出现事务 四、事务的版本支持 五、事务的提交方式 六、事务的常见操作方式 6.1 事务的开始与回滚 七、事务的隔离性 7.1 隔离级别的设置与查看 7.1.1 全局隔离级别 7.1.2 会话隔离级别 7.2 四种隔离级别 7.2.1 …...

DKP-PC:解决预测编码误差传播延迟与衰减的新方法

1. 项目概述在深度学习领域,反向传播(Backpropagation, BP)算法长期以来一直是训练神经网络的核心方法。然而,BP算法存在两个关键问题:更新锁定(update locking)和非局部性(non-loca…...

进程替换库函数

1.程序替换 预备工作 上级目录(…)下的fork目录下的makefile文件拷贝到当前目录并且命名为Makefile把proc1替换为myexec1.1 现象和原理 先看现象,可以看到执行了main函数第一句代码,接着就执行的是ls -a -l这时候回想fork的两种用…...

以知识驱动 AIAD 行业进化

AIAD 智库 — AI-Augmented Design 行业百科与实践指南 重塑设计的底层逻辑 从 CAD 到 AI-Native 四大内容支柱 支柱描述条目数📖 概念与百科定义行业标准术语,建立专业基石与"定义权"12 深度条目🔬 技术前沿与深度解析展示底层技…...

Coze低代码模式和Vibe Coding的区别

版权声明 本文原创作者:谷哥的小弟 作者博客地址:http://blog.csdn.net/lfdfhl Coze的版本 Coze(扣子)是字节跳动推出的一站式AI智能体开发平台,历经两年发展,已从单纯的智能体搭建工具演进为完整的AI应用开发生态。 Coze国内版与海外版最核心的区别在于,它们是两套完…...

通过 curl 命令直接调用 Taotoken 聚合接口进行快速测试与排错

通过 curl 命令直接调用 Taotoken 聚合接口进行快速测试与排错 1. 准备工作 在开始调用 Taotoken 聊天补全接口前,需要准备好以下两项信息:有效的 API Key 和模型 ID。API Key 可在 Taotoken 控制台的「API 密钥」页面生成,模型 ID 则需前往…...

SIMA 2:多模态大模型在3D虚拟环境中的交互革命

1. 项目概述:当通用AI遇上虚拟世界去年第一次接触SIMA项目时,我就被这个将大语言模型与3D环境交互结合的思路惊艳到了。如今看到升级版的SIMA 2基于Gemini架构卷土重来,不禁让人好奇:当最先进的多模态大模型遇上复杂的虚拟环境&am…...

NVIDIA Profile Inspector:解锁显卡驱动隐藏配置的终极调校工具

NVIDIA Profile Inspector:解锁显卡驱动隐藏配置的终极调校工具 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector NVIDIA Profile Inspector 是一款功能强大的开源工具,专为 NVIDI…...

TV2TV:文本与视频双向控制的AI生成技术解析

1. 项目概述:当电视节目开始"自我创作"去年我在参与一档综艺节目的后期制作时,导演突然提出一个疯狂的想法:"能不能让AI根据嘉宾聊天的文字记录,自动生成对应的节目画面?"这个看似天马行空的需求&…...

IntelliChat开源智能聊天机器人后端:架构解析与RAG实战部署指南

1. 项目概述:一个能“思考”的聊天机器人后端最近在折腾一个叫 IntelliChat 的项目,这名字听起来就挺有意思——“智能节点”下的“智能聊天”。说白了,这就是一个开源的、可以自己部署的聊天机器人后端引擎。它不像你手机里那些傻乎乎的、只…...

BotW-Save-Manager:快速实现Switch与WiiU存档互转的终极解决方案

BotW-Save-Manager:快速实现Switch与WiiU存档互转的终极解决方案 【免费下载链接】BotW-Save-Manager BOTW Save Manager for Switch and Wii U 项目地址: https://gitcode.com/gh_mirrors/bo/BotW-Save-Manager BotW-Save-Manager是一款专为《塞尔达传说&am…...

ToolFlow:基于工作流引擎的LLM工具编排框架设计与实战

1. 项目概述:当代码生成器开始“思考”工作流最近在GitHub上看到一个挺有意思的项目,叫ToolFlow。初看标题,你可能会觉得这又是一个平平无奇的工具库,但点进去细看,它的定位其实相当独特:一个专为大型语言模…...

provision-core:现代基础设施供应的核心编排引擎设计与实践

1. 项目概述:一个面向现代基础设施的“核心引擎”如果你和我一样,在云原生和基础设施即代码(IaC)的浪潮里摸爬滚打了好几年,那你肯定经历过这样的场景:面对一个全新的项目,你需要快速拉起一套包…...

量子储层计算在金融预测中的创新应用

1. 量子储层计算基础解析量子储层计算(Quantum Reservoir Computing, QRC)是近年来量子机器学习领域最具突破性的技术之一。与传统的神经网络不同,QRC利用量子系统的自然动力学特性作为"计算资源",特别适合处理具有时间…...

Clerk与JavaScript SDK:现代Web应用身份管理的黄金组合

1. 项目概述:为什么是 Clerk 与 JavaScript 的黄金组合? 如果你正在构建一个需要用户系统的现代 Web 应用,无论是 SaaS 产品、社区论坛还是内部工具,那么“用户认证与授权”这个坎儿你肯定绕不过去。传统的做法是什么&#xff1f…...

Web3开发实战:基于luzhenqian/web3-examples的DApp构建指南

1. 项目概述与核心价值最近在捣鼓一些去中心化应用(DApp)的原型,发现很多教程要么太理论化,要么就是代码片段零散,想找个能直接跑起来、覆盖主流场景的完整例子集,还真得费一番功夫。直到我遇到了luzhenqia…...