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

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

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

该题考察的是二分法,二分法求左右边界问题

//荷兰国旗问题,两次二分
public class Problem_0034_FindFirstAndLastPositionOfElementInSortedArray {public static int[] searchRange(int[] nums, int target) {int[] ans = { -1, -1 };if (nums == null || nums.length == 0) {return ans;}ans[0] = findFirst(nums, target);ans[1] = findLast(nums, target);return ans;}public static int findFirst(int[] arr, int num) {int L = 0;int R = arr.length - 1;int ans = -1;int mid = 0;while (L <= R) {mid = L + ((R - L) >> 1);if (arr[mid] < num) {L = mid + 1;} else if (arr[mid] > num) {R = mid - 1;} else {ans = mid;//  此处因为要找的target最左边界,所有移动R为mid - 1,再看左边还有没有target值R = mid - 1;}}return ans;}public static int findLast(int[] arr, int num) {int L = 0;int R = arr.length - 1;int ans = -1;int mid = 0;while (L <= R) {mid = L + ((R - L) >> 1);if (arr[mid] < num) {L = mid + 1;} else if (arr[mid] > num) {R = mid - 1;} else {ans = mid;//  此处因为要找的target最右边界,所有移动L为mid + 1,再看右边还有没有target值L = mid + 1;}}return ans;}
}
http://www.lryc.cn/news/281594.html

相关文章:

  • js树过滤
  • Java多线程并发篇----第十六篇
  • 测评结果:免费的“文心一言3.5”香,但是付费的产品质量更高
  • Matlab GUI设计基础范例(可以一步一步跟着做)
  • @Transactional(rollbackFor = {Exception.class})与 @Transactional区别
  • 数据结构——二叉树(先序、中序、后序及层次四种遍历(C语言版))超详细~ (✧∇✧) Q_Q
  • 如何快速打造属于自己的接口自动化测试框架
  • 人工智能在数据安全中的应用场景
  • 2024.1.16每日一题
  • python入门,数据容器的通用操作(len,max,min,sorted)
  • 运筹说 第67期 | 动态规划模型的建立与求解
  • 大模型压缩与优化的技术原理与创新方法
  • ConcurrentSkipListMap 深度解析
  • Vue学习笔记6--配置代理
  • 嵌入式培训机构四个月实训课程笔记(完整版)-C++和QT编程第三天-C++类和对象高级应用(物联技术666)
  • SAP中采购文档价格条件可以删除吗?
  • Baumer工业相机堡盟工业相机如何通过NEOAPI SDK设置硬件触发模式(C++)
  • 嵌入式培训机构四个月实训课程笔记(完整版)-Linux网络编程第二天-tcp编程练习(物联技术666)
  • 【IC前端虚拟项目】MVU子模块DS文档编写与注意事项
  • Postgresql 12.2 + PostGIS 3.0.1 安装部署
  • MAC iterm 显示git分支名
  • 智慧公厕:利用物联网、云计算和人工智能实现智能化管理与控制
  • 【漏洞复现】Apache Tomcat AJP文件包含漏洞(CVE-2020-1938)
  • [渗透测试学习] Hospital - HackTheBox
  • C技能树-学习笔记(1-2)C语言概述和数据类型
  • 设计模式入门
  • EasyExcel下载EXCEL文件,后台通过流形式输出到前端浏览器下载方式输出
  • Pandas实战100例 | 案例 56: 创建多重索引
  • 解决“nacos默认secret.key配置不当权限绕过漏洞“
  • 一款好用的开源思维导图软件 docker部署教程