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

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

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

方法一、二分查找法

题目要求时间复杂度为 O(log n) ,首先想到的是二分查找法。
起始位置:查找target第一次出现的位置,一直找到不满足target <= nums[mid]为止。但是结束位置如何找呢?
结束位置:找第一个大于target的值的位置,然后前一个位置就是目标值的结束位置

Swift

/*1.开始位置即为target第一次出现的位置,二分查找即可2.结束位置为第一个大于target的位置-13.校验索引是否满足条件及越界检查等*/func searchRange(_ nums: [Int], _ target: Int) -> [Int] {//开始位置let left = binarySearch(nums, true, target)//结束位置let right = binarySearch(nums, false, target)-1//校验if left <= right && right<nums.count && (nums[left] == nums[right]) {return [left, right]}return [-1, -1]}//二分查找target在nums中的索引,lower为true表示查找第一个大于等于target的索引func binarySearch(_ nums: [Int], _ lower: Bool, _ target: Int) -> Int {var left = 0, right = nums.count - 1, ans = nums.countwhile left <= right {let mid = (left + right) >> 1if target < nums[mid] || (lower && target <= nums[mid]) {right = mid - 1ans = mid}else {left = mid + 1}}return ans}

OC

//非严格递增的序列中查找target的起始位置
-(NSArray *)searchRange:(NSArray <NSNumber *>*)numstarget: (NSInteger)target {NSInteger leftIdx = [self binarySearch:nums lower:YES target:target];NSInteger rightIdx = [self binarySearch:nums lower:NO target:target];if (leftIdx <= rightIdx && rightIdx<nums.count && ([nums[leftIdx] integerValue] == [nums[rightIdx] integerValue])) {return @[@(leftIdx), @(rightIdx)];}return @[@-1, @-1];
}/// 二分查找,在nums数组中大于或大于等于target的第一个索引位置
/// - Parameters:
///   - nums: 有序数列
///   - lower: 为true表示大于等于target的索引,为false表示大于target的索引
///   - target: 目标值
- (NSInteger)binarySearch:(NSArray *)nums lower:(BOOL)lower target:(NSInteger)target {NSInteger left = 0, right = nums.count-1;NSInteger ans = nums.count;while (left <= right) {NSInteger mid = (left + right) >> 1;if (target < [nums[mid] integerValue] || (lower && target <= [nums[mid] integerValue])) {right = mid - 1;ans = mid;}else {left = mid + 1;}}return ans;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/625197.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java 线程

1. 实现多线程的 2 种方式 Oracle 官网的文档中给出了 2 种实现多线程的方式&#xff1a; 实现 Runnable 接口&#xff1b;继承 Thread 类。 以上两种方式都会调用 Thread.run() 方法&#xff0c;区别是&#xff1a; 实现 Runnable 接口&#xff0c;只是执行 Thread.run() …

【迅搜17】SCWS分词(二)自定义字典及分词器

SCWS分词&#xff08;二&#xff09;自定义字典及分词器 经过上篇文章的学习&#xff0c;相信大家对分词的概念已经有了更深入的了解了吧。我们也知道了&#xff0c;SCWS 是 XS 中的一个重要组成部分&#xff0c;但它也是可以单独拿出来使用的。而对于分词器来说&#xff0c;不…

【新】Unity Meta Quest MR 开发(一):Passthrough 透视配置

文章目录 &#x1f4d5;教程说明&#x1f4d5;配置透视的串流调试功能&#x1f4d5;第一步&#xff1a;设置 OVRManager&#x1f4d5;第二步&#xff1a;添加 OVRPassthroughLayer 脚本&#x1f4d5;第三步&#xff1a;在场景中添加虚拟物体&#x1f4d5;第四步&#xff1a;设置…

202406读书笔记|《沉睡的线条世界》——翻山越岭,只为与你分享点滴的快乐

《沉睡的线条世界》登登登Dn绘著&#xff0c;简简单单的小画&#xff0c;简简单单的线条&#xff0c;简简单单的语言&#xff0c;温馨又有一点暖心。 怎样的你都好&#xff0c;做最真实的自己。 部分节选如下&#xff1a; 愿你我永远有热情&#xff0c;永远能为生活的每一个小惊…

阳光抑郁症测试

大部分人对抑郁症的理解&#xff0c;就是每天无精打采&#xff0c;死气沉沉&#xff0c;可实际上&#xff0c;还有一种阳光抑郁症&#xff0c;完全不是这个样子。这种抑郁症的人&#xff0c;做事情非常有活力&#xff0c;魅力十足&#xff0c;给人感觉十分有自信&#xff0c;但…

快速排序【hoare版本】【挖坑法】【双指针法】(数据结构)

快速排序是Hoare于1962年提出的一种二叉树结构的交换排序方法&#xff0c;其基本思想为&#xff1a;任取待排序元素序列中 的某元素作为基准值&#xff0c;按照该排序码将待排序集合分割成两子序列&#xff0c;左子序列中所有元素均小于基准值&#xff0c;右子序列中所有元素均…

如何写年终汇报

每年最头疼的事儿就是写年终个人汇报&#xff08;总结&#xff09;。有时还有篇幅限制&#xff0c;疼上加疼。 根据个人经验和参考其他同事的汇报&#xff0c;做了一个简要的总结&#xff0c;方便以后写汇报使用。 个人汇报大的逻辑是&#xff1a;做了什么做的怎么样&#xff…

MySQL多表查询(改进版)

1.创建student和score表 mysql> CREATE TABLE student (-> id INT(10) NOT NULL UNIQUE PRIMARY KEY ,-> name VARCHAR(20) NOT NULL ,-> sex VARCHAR(4) ,-> birth YEAR,-> department VARCHAR(20) ,-> address VARCHAR(50)-> ); Query O…

242.【2023年华为OD机试真题(C卷)】螺旋数字矩阵(JavaPythonC++JS实现)

🚀点击这里可直接跳转到本专栏,可查阅顶置最新的华为OD机试宝典~ 本专栏所有题目均包含优质解题思路,高质量解题代码(Java&Python&C++&JS分别实现),详细代码讲解,助你深入学习,深度掌握! 文章目录 一. 题目-螺旋数字矩阵二.解题思路三.题解代码Python题解…

SpringCloud Nacos服务注册中心和配置中心

一、什么是Nacos&#xff1f; 官方介绍是这样的&#xff1a; Nacos 致力于帮助您发现、配置和管理微服务。Nacos 提供了一组简单易用的特性集&#xff0c;帮助您实现动态服务发现、服务配置管理、服务及流量管理。 Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。 Na…

用python批量实现文件夹中所有pdf转成图片并插入到一个word文件中

要实现这个任务&#xff0c;你需要使用Python的几个库&#xff1a;PyPDF2 用于处理PDF文件&#xff0c;python-docx 用于操作Word文件&#xff0c;PIL&#xff08;或Pillow&#xff09;用于处理图片。 首先&#xff0c;确保你已经安装了这些库。如果没有&#xff0c;你可以使用…

Java 方法以及在计算机内部的调用问题

修饰符 返回值类型 方法名( 形参列表 ){ 方法体代码(需要执行的功能代码) return 返回值; } 方法在内种没有先后顺序&#xff0c;但是不能把一个方法定义在另一个方法中。 方法的返回值类型写void&#xff08;无返回申明&#xff09;时&#xff0c;方法内不能使用return返回数…

Linux中放大字体

环境&#xff1a;VMware17Pro&#xff0c;Ubuntu22.04 在显示设置外观中只看到图标放大的调整&#xff0c;没看到字体大小设置 不按照常规设置&#xff0c;点开下面的辅助功能->大号文本&#xff08;没有设置具体字号的选项&#xff0c;但是可以放大&#xff09; 效果图如下…

day-10 删除排序链表中的重复元素

思路 先统计每个值出现的次数&#xff0c;然后将出现次数为一的节点链接为一个链表即可 解题方法 while(t!null){ //统计每个值出现次数 arr[t.val100]1; tt.next; } while(t!null&&arr[t.val100]!1) tt.next;//确定返回的头结点 ttt; while(t!null&&t.next…

项目解决方案:多个分厂的视频监控汇聚到总厂

目 录 1、概述 2、建设目标及需求 2.1 建设目标 2.2 需求描述 2.3 需求分析 3. 设计依据与设计原则 3.1 设计依据 3.2设计原则 1、先进性与适用性 2、经济性与实用性 3、可靠性与安全性 4、开放性 5、可扩充性 6、追求最优化的系统设备配置…

Zynq7020 使用 Video Processing Subsystem 实现图像缩放

1、前言 没玩过图像缩放都不好意思说自己玩儿过FPGA&#xff0c;这是CSDN某大佬说过的一句话&#xff0c;鄙人深信不疑。。。 目前市面上主流的FPGA图像缩放方案如下&#xff1a;1&#xff1a;Xilinx的HLS方案&#xff0c;该方案简单&#xff0c;易于实现&#xff0c;但只能用…

MySQL语句 | 使用DATE_FORMAT()对查询结果按日、周、月分组统计

文章目录 语法举个通用的例子 按照年月日进行分组统计举个通用的例子举个实际的例子 在MySQL中&#xff0c; DATE_FORMAT() 函数可用于将日期按照指定的格式进行格式化&#xff0c;也可用于对数据记录按照不同的时间维度进行分组 语法 DATE_FORMAT(date, format)其中&#xf…

java+vue基于Spring Boot的渔船出海及海货统计系统

该渔船出海及海货统计系统采用B/S架构、前后端分离进行设计&#xff0c;并采用java语言以及springboot框架进行开发。该系统主要设计并完成了管理过程中的用户注册登录、个人信息修改、用户信息、渔船信息、渔船航班、海货价格、渔船海货、非法举报、渔船黑名单等功能。该系统操…

Elasticsearch安装Windows版

目录 1.&#xff1a;下载安装包&#xff0c;选择指定的版本&#xff0c;这里选择了7.8.0&#xff0c;官网下载地址&#xff1a; ​编辑 2&#xff1a;下载好之后解压&#xff0c;解压之后是这样的&#xff1a; 3&#xff1a;配置环境变量&#xff0c;跟JDK一样&#xff0c;…