力扣面试150题--插入区间和用最少数量的箭引爆气球

Day 28

题目描述

在这里插入图片描述

思路

初次思路:借鉴一下昨天题解的思路,将插入的区间与区间数组作比较,插入到升序的数组中,其他的和(合并区间)做法一样。
注意需要特殊处理一下情况,插入区间比数组中最后一个区间的起始点大,这种情况,在循环中不会计算到插入区间,单独处理一下。

class Solution {public int[][] insert(int[][] intervals, int[] newInterval) {List<int[]> merged = new ArrayList<int[]>();if(intervals.length==0){//区间数组为空merged.add(new int[]{newInterval[0],newInterval[1]});return merged.toArray(new int[merged.size()][]);   }int start=0,end=0;for (int i = 0; i < intervals.length;i++) {if(newInterval[0]<intervals[i][0]) {//将插入区间到数组中start = newInterval[0];end = newInterval[1];newInterval[0] = intervals[i][0];newInterval[1] = intervals[i][1];i--;}else{start = intervals[i][0];end = intervals[i][1];}if(merged.size()==0||merged.get(merged.size()-1)[1]<start) {merged.add(new int[]{start, end});}else{merged.get((merged.size()-1))[1] = Math.max(merged.get(merged.size()-1)[1], end);}}if(newInterval[0]>=intervals[intervals.length-1][0]){//特殊处理一下if(merged.size()==0||merged.get(merged.size()-1)[1]<newInterval[0]) {merged.add(new int[]{newInterval[0], newInterval[1]});}else{merged.get((merged.size()-1))[1] = Math.max(merged.get(merged.size()-1)[1], newInterval[1]);}}return merged.toArray(new int[merged.size()][]);   }
}

问题:时间复杂度比较高,虽然通过了
做法:注意题目条件,给定的区间数组中的区间是不重叠的,那么我们需要插入一个新的区间,只需要找到这个与这个插入区间有重叠的区间,合并成一个大区间即可。

class Solution {public int[][] insert(int[][] intervals, int[] newInterval) {List<int[]> res = new ArrayList<int[]>();if(intervals.length==0){//数组为空特殊处理res.add(new int[]{newInterval[0],newInterval[1]});return res.toArray(new int[res.size()][]);}int x=0;int start =newInterval[0],end=newInterval[1];//初始化for (int i = 0; i < intervals.length; i++) {if(intervals[i][1] <newInterval[0]) {//说明这个区间和新插入区间没有交集res.add(new int[]{intervals[i][0],intervals[i][1]});}else if(intervals[i][0] > newInterval[1]) {if(x==0){//由于数组是按照起始点的升序排列。证明插入的区间到这里已经找到最大的合并区间res.add(new int[]{start,end});x=1;}//说明这个区间和新插入区间没有交集res.add(new int[]{intervals[i][0],intervals[i][1]});}else{//扩大合并区间start=Math.min(start,intervals[i][0]);end=Math.max(end,intervals[i][1]);}}if(x==0){//排除特殊情况,即为数组中所有区间在插入这个区间后合并为一个大区间res.add(new int[]{start,end});}return res.toArray(new int[res.size()][]);}
}

题目描述

在这里插入图片描述

思路

首先我们来中翻中一下:这题所谓的最少数量的箭,可以理解为多个区间中的重叠的区间,所以这道题的目的是为了找到这个区间数组有几个重叠区间。
做法

  1. 将所有气球按照起始点升序进行排序
  2. 创建start和end,用来记录当前重合区间的范围(初始设置为第一个气球的范围),初始设置箭数sum为1。
  3. 从前向后遍历,由于此时气球是有序的,比较当前气球和重合范围(start,end)是否重合,也就是比较当前气球的起始点是否小于等于end(不比较start的原因在于是升序的,下一个气球的起始点一定比start大
  4. 如果小于等于end,说明气球在重合区间,需要更新重合区间(这里建议画图理解),更新看代码。
  5. 如果大于end,说明这个气球和之前的所有气球不能一箭射穿,就将箭数加1
    注意:箭初始设置为1,目的就是将与第一个气球有重合区间的所有气球都射穿,如果一个气球不在重合区间,就需要多一把箭。
class Solution {public int findMinArrowShots(int[][] points) {if(points.length==0){//为空特殊处理return  0;}int start=0,end=0,sum=1;Arrays.sort(points, new Comparator<int[]>() {//按照起始点进行升序排序public int compare(int[] interval1, int[] interval2) {return Integer.compare(interval1[0], interval2[0]);}});//排序start=points[0][0];end=points[0][1];for(int i=1;i<points.length;i++){if(points[i][0]<=end){//如果该区间的起始点比目前记录的区间结束点还小,说明有重合start=Math.max(start,points[i][0]);//修改区间的起始点end=Math.min(end,points[i][1]);//修改区间的结束点//这里就是收缩到目前的最小重合区间}else{//说明这个气球不在之前的重合区间,一箭射不爆sum++;//计数器加1 start=points[i][0];end=points[i][1];//将这个气球的范围作为新的区间}}return sum;}
}

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

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

相关文章

【Java面试笔记:基础】4.强引用、软引用、弱引用、幻象引用有什么区别?

1. 引用类型及其特点 强引用(Strong Reference): 定义:最常见的引用类型,通过new关键字直接创建。回收条件:只要强引用存在,对象不会被GC回收。示例:Object obj = new Object(); // 强引用特点: 强引用是导致内存泄漏的常见原因(如未及时置为null)。手动断开引用:…

ycsb性能测试的优缺点

YCSB&#xff08;Yahoo Cloud Serving Benchmark&#xff09;是一个开源的性能测试框架&#xff0c;用于评估分布式系统的读写性能。它具有以下优点和缺点&#xff1a; 优点&#xff1a; 简单易用&#xff1a;YCSB提供了简单的API和配置文件&#xff0c;使得性能测试非常容易…

基于SpringBoot的校园赛事直播管理系统-项目分享

基于SpringBoot的校园赛事直播管理系统-项目分享 项目介绍项目摘要管理员功能图用户功能图项目预览首页总览个人中心礼物管理主播管理 最后 项目介绍 使用者&#xff1a;管理员、用户 开发技术&#xff1a;MySQLJavaSpringBootVue 项目摘要 随着互联网和移动技术的持续进步&…

Nginx​中间件的解析

目录 一、Nginx的核心架构解析 二、Nginx的典型应用场景 三、Nginx的配置优化实践 四、Nginx的常见缺陷与漏洞 一、Nginx的核心架构解析 ​​事件驱动与非阻塞IO模型​​ Nginx采用基于epoll/kq等系统调用的事件驱动机制&#xff0c;通过异步非阻塞方式处理请求&#xff0c;…

杭州小红书代运营公司-品融电商:全域增长策略的实践者

杭州小红书代运营公司-品融电商&#xff1a;全域增长策略的实践者 在品牌竞争日趋激烈的电商领域&#xff0c;杭州品融电商作为一家专注于品牌化全域运营的服务商&#xff0c;凭借其“效品合一”方法论与行业领先的小红书代运营能力&#xff0c;已成为众多品牌实现市场突围的重…

【映客直播-注册/登录安全分析报告】

前言 由于网站注册入口容易被黑客攻击&#xff0c;存在如下安全问题&#xff1a; 暴力破解密码&#xff0c;造成用户信息泄露短信盗刷的安全问题&#xff0c;影响业务及导致用户投诉带来经济损失&#xff0c;尤其是后付费客户&#xff0c;风险巨大&#xff0c;造成亏损无底洞…

Android audio_policy_configuration.xml加载流程

目录 一、audio_policy_configuration.xml文件被加载流程 1、AudioPolicyService 创建阶段 2、createAudioPolicyManager 实现 3、AudioPolicyManager 构造 4、配置文件解析 loadConfig 5、核心解析逻辑 PolicySerializer::deserialize 二、AudioPolicyConfig类解析 1、…

使用 Docker 安装 Elastic Stack 并重置本地密码

Elastic Stack&#xff08;也被称为 ELK Stack&#xff09;是一个非常强大的工具套件&#xff0c;用于实时搜索、分析和可视化大量数据。Elastic Stack 包括 Elasticsearch、Logstash、Kibana 等组件。本文将展示如何使用 Docker 安装 Elasticsearch 并重置本地用户密码。 ###…

Unitest和pytest使用方法

unittest 是 Python 自带的单元测试框架&#xff0c;用于编写和运行可重复的测试用例。它的核心思想是通过断言&#xff08;assertions&#xff09;验证代码的行为是否符合预期。以下是 unittest 的基本使用方法&#xff1a; 1. 基本结构 1.1 创建测试类 继承 unittest.TestC…

git 版本提交规范

Git 提交规范&#xff08;Git Commit Message Convention&#xff09;是为了让项目的提交历史更加清晰、可读、便于追踪和自动化工具解析。常见的规范之一是 Conventional Commits&#xff0c;下面是一个推荐的格式规范&#xff1a; &#x1f31f; 提交信息格式&#xff08;Con…

stat判断路径

int stat(const char *pathname, struct stat *buf); pathname&#xff1a;用于指定一个需要查看属性的文件路径。 buf&#xff1a;struct stat 类型指针&#xff0c;用于指向一个 struct stat 结构体变量。调用 stat 函数的时候需要传入一个 struct stat 变量的指针&#xff0…

学习Docker遇到的问题

目录 1、拉取hello-world镜像报错 1. 检查网络连接 排查: 2. 配置 Docker 镜像加速器(推荐) 具体解决步骤: 1.在服务器上创建并修改配置文件,添加Docker镜像加速器地址: 2. 重启Docker 3. 拉取hello-world镜像 2、删除镜像出现异常 3、 容器内部不能运行ping命令 …

安宝特案例 | AR如何大幅提升IC封装厂检测效率?

前言&#xff1a;如何提升IC封装厂检测效率&#xff1f; 在现代电子产品的制造过程中&#xff0c;IC封装作为核心环节&#xff0c;涉及到复杂处理流程和严格质量检测。这是一家专注于IC封装的厂商&#xff0c;负责将来自IC制造商的晶圆进行保护、散热和导通处理。整个制程繁琐…

【Linux网络与网络编程】07.应用层协议HTTPS

HTTP 协议内容都是按照文本的方式明文传输的&#xff0c;这就导致在传输过程中出现一些被篡改的情况。HTTPS 就是在 HTTP 协议的基础上引入了一个加密层的应用层协议。 1. 基础概念 1.1 加密与解密 加密就是把明文&#xff08;要传输的信息&#xff09;进行一系列变换&#x…

【k8s】PV,PVC的回收策略——return、recycle、delete

PV 和 PVC 的回收策略主要用于管理存储资源的生命周期&#xff0c;特别是当 PVC 被删除时&#xff0c;PV 的处理方式。回收策略决定了 PV 在 PVC 被删除后的行为。 回收策略的类型 Kubernetes 提供了三种主要的回收策略&#xff0c;用于管理 PV 的生命周期&#xff1a; Reta…

2023蓝帽杯初赛内存取证-2

直接使用mimikatz插件来获取用户密码&#xff1a; vol.py --plugin/opt/volatility/plugins -f memdump.mem --profile Win7SP1x64 mimikatz 答案&#xff1a;3w.qax.com

使用dompurify修复XSS跨站脚本缺陷

1. 问题描述 漏洞扫描说有一个低危漏洞&#xff0c;容易被跨站脚本攻击XSS。 2. 使用dompurify修复 DOMPurify is a DOM-only, super-fast, uber-tolerant XSS sanitizer for HTML, MathML and SVG. 简单来说&#xff0c;我们可以使用 dompurify 处理xss跨站脚本攻击。 2.…

【c语言】指针和数组笔试题解析

一维数组: //数组名a如果既不单独放在sizeof()中&#xff0c;也不与&结合&#xff0c;那么就表示数组首元素的大小 //a一般表示数组首元素地址&#xff0c;只有两种情况表示整个数组&#xff0c;sizeof(arr)表示整个数组的大小&#xff0c;&arr表示数组的地址 int a[]…

机器人进阶---视觉算法(六)傅里叶变换在图像处理中怎么用

傅里叶变换在图像处理中怎么用 傅里叶变换的基本原理应用场景Python代码示例逐行解释总结傅里叶变换在图像处理中是一种重要的工具,它将图像从空间域转换到频域,从而可以对图像的频率特性进行分析和处理。傅里叶变换在图像滤波、图像增强、图像压缩和图像分析等方面都有广泛应…

深度学习与总结JVM专辑(七):垃圾回收器—CMS(图文+代码)

CMS垃圾收集器深度解析教程 1. 前言&#xff1a;为什么需要CMS&#xff1f;2. CMS 工作原理&#xff1a;一场与时间的赛跑2.1. 初始标记&#xff08;Initial Mark&#xff09;2.2. 并发标记&#xff08;Concurrent Mark&#xff09;2.3. 重新标记&#xff08;Remark&#xff09…