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

【LeetCode:34. 在排序数组中查找元素的第一个和最后一个位置 | 二分】

在这里插入图片描述

🚀 算法题 🚀

🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀
🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨
🌲 作者简介:硕风和炜,CSDN-Java领域新星创作者🏆,保研|国家奖学金|高中学习JAVA|大学完善JAVA开发技术栈|面试刷题|面经八股文|经验分享|好用的网站工具分享💎💎💎
🌲 恭喜你发现一枚宝藏博主,赶快收入囊中吧🌻
🌲 人生如棋,我愿为卒,行动虽慢,可谁曾见我后退一步?🎯🎯

🚀 算法题 🚀

在这里插入图片描述

在这里插入图片描述

🍔 目录

    • 🚩 题目链接
    • ⛲ 题目描述
    • 🌟 求解思路&实现代码&运行结果
      • ⚡ 二分
        • 🥦 求解思路
        • 🥦 实现代码
        • 🥦 运行结果
    • 💬 共勉

🚩 题目链接

  • 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]

提示:

0 <= nums.length <= 105
-109 <= nums[i] <= 109
nums 是一个非递减数组
-109 <= target <= 109

🌟 求解思路&实现代码&运行结果


⚡ 二分

🥦 求解思路
  1. 根据题目的要求,我们需要找到大于等于target最左侧的元素,我们通过二分来求解。
  2. 因为题目让我们求解的是等于target的第一个元素位置和最后一个元素位置,所以,我们进行俩次二分查找,第一次二分直接去找target,第二次二分去找target+1。
  3. 需要注意的是,第一次二分结束的时候,我们需要判断,当前位置是否超过了数组的长度,或者是当前位置的元素是否等于target,如果满足任意一个,直接返回{-1,-1}。
  4. 实现代码如下所示:
🥦 实现代码
class Solution {public int[] searchRange(int[] nums, int target) {int l = binarySerach(nums, target);if (l == nums.length || nums[l] != target) {return new int[] { -1, -1 };}int r = binarySerach(nums, target + 1) - 1;return new int[] { l, r };}public int binarySerach(int[] nums, int target) {int n = nums.length;int left = -1, right = n;while (left + 1 < right) {int mid = left + right >> 1;if (nums[mid] >= target) {right = mid;} else {left = mid;}}return right;}
}
🥦 运行结果

在这里插入图片描述


💬 共勉

最后,我想和大家分享一句一直激励我的座右铭,希望可以与大家共勉!

在这里插入图片描述

在这里插入图片描述

http://www.lryc.cn/news/273343.html

相关文章:

  • 年度征文|回顾2023我的CSDN
  • 3.无重复字符的最长子串(滑动窗口,C解答)
  • 什么是系统设计 – 学习系统设计
  • 基于Python的城市热门美食数据可视化分析系统
  • 万字长文谈自动驾驶occupancy感知
  • KBDNO1.DLL文件缺失,软件或游戏无法启动运行,怎样快速修复
  • 计算机网络【EPOLL 源码详解】
  • 第82讲:MySQL Binlog日志的滚动
  • 2024.1.3C语言补录 宏函数
  • 鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之线性布局容器Column组件
  • 快手推荐算法工程师三面回顾
  • Sonarqube安装(Docker)
  • 双击shutdown.bat关闭Tomcat报错:未设置关闭端口~
  • HLS 2017.4 导出 RTL 报错:ERROR: [IMPL 213-28] Failed to generate IP.
  • 【Kubernetes】kubectl 常用命令
  • 鸿蒙开发第一天
  • Midjourney表情包制作及变现最全教程
  • UNIAPP中借助store+watch完成实时数据
  • COLMAP 三维重建 笔记
  • 即时设计:一键查看设计稿与页面差异,让设计师的工作更便捷高效
  • 知识库问答LangChain+LLM的二次开发:商用时的典型问题及其改进方案
  • Mac内心os:在下只是个工具,指望我干人事?
  • 2024年最新远程控制软件
  • 华为鸿蒙应用--文件管理工具(鸿蒙工具)-ArkTs
  • Python基础语法笔记 tkinter的简单使用
  • SSL/TLS 握手过程详解
  • B端产品经理学习-对用户进行需求挖掘
  • 高清网络视频监控平台的应用-城市大交通系统视联网
  • java设计小分队01
  • instant ngp win11 安装笔记