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

整数数组区间的插入与删除

相似题参考:

56. Merge Intervals - 力扣(LeetCode)合并区间

57. 插入区间 - 力扣(LeetCode)

1272. 删除区间

package Jerry;import org.junit.Assert;
import org.junit.Test;import java.util.ArrayList;
import java.util.List;// Task: Implement a class named 'RangeList'
// A pair of integers define a range, for example: [1, 5). This range includes integers: 1, 2, 3, and 4.
// A range list is an aggregate of these ranges: [1, 5), [10, 11), [100, 201)public class RangeList {// 结果private List<int[]> intervals = new ArrayList<>();// toString 使用的静态常量private static final String LEFT = "[";private static final String RIGHT = ")";private static final String FLAG = ", ";private static final String BLANK = " ";/*** junit单元测试*/@Testpublic void test() {RangeList rl = new RangeList();System.out.println(rl.toString()); // Should be ""Assert.assertEquals(rl.toString(), "");rl.add(1, 5);//rl.add(new int[]{1, 5});System.out.println(rl.toString()); // Should be: "[1, 5)"Assert.assertEquals(rl.toString(), "[1, 5)");rl.add(10, 20);System.out.println(rl.toString()); // Should be: "[1, 5) [10, 20)"Assert.assertEquals(rl.toString(), "[1, 5) [10, 20)");rl.add(20, 20);System.out.println(rl.toString()); // Should be: "[1, 5) [10, 20)"Assert.assertEquals(rl.toString(), "[1, 5) [10, 20)");rl.add(20, 21);System.out.println(rl.toString()); // Should be: "[1, 5) [10, 21)"Assert.assertEquals(rl.toString(), "[1, 5) [10, 21)");rl.add(2, 4);System.out.println(rl.toString()); // Should be: "[1, 5) [10, 21)"Assert.assertEquals(rl.toString(), "[1, 5) [10, 21)");rl.add(3, 8);System.out.println(rl.toString()); // Should be: "[1, 8) [10, 21)"Assert.assertEquals(rl.toString(), "[1, 8) [10, 21)");rl.remove(10, 10);System.out.println(rl.toString()); // Should be: "[1, 8) [10, 21)"Assert.assertEquals(rl.toString(), "[1, 8) [10, 21)");rl.remove(10, 11);System.out.println(rl.toString()); // Should be: "[1, 8) [11, 21)"Assert.assertEquals(rl.toString(), "[1, 8) [11, 21)");rl.remove(15, 17);System.out.println(rl.toString()); // Should be: "[1, 8) [11, 15) [17, 21)"Assert.assertEquals(rl.toString(), "[1, 8) [11, 15) [17, 21)");rl.remove(3, 19);System.out.println(rl.toString()); // Should be: "[1, 3) [19, 21)"Assert.assertEquals(rl.toString(), "[1, 3) [19, 21)");// 新增移除区间不存在的情况rl.remove(4, 18);System.out.println(rl.toString()); // Should be: "[1, 3) [19, 21)"Assert.assertEquals(rl.toString(), "[1, 3) [19, 21)");// 新增添加区间覆盖所有分区的情况rl.add(1, 21);System.out.println(rl.toString()); // Should be: "[1, 21)"Assert.assertEquals(rl.toString(), "[1, 21)");// 新增移除区间覆盖所有分区的情况rl.remove(1, 21);System.out.println(rl.toString()); // Should be: ""Assert.assertEquals(rl.toString(), "");}void add(int start, int end) {add(new int[]{start, end});}/*** 新增一个区间到区间列表中** @param range - 整数数组*/void add(int[] range) {// 参数检查if (!checkParams(range)) {return;}// 原来的区间为空if (intervals.isEmpty()) {intervals.add(range);}// 存储新增&合并后的结果ArrayList<int[]> res = new ArrayList<>();// 记录res是否已经add输入的区间boolean hadInsert = false;for (int[] item : intervals) {// 1 不相交,后续元素存在相交可能性// 新增区间 = [10,12)// 遍历节点item = [6,8)if (item[1] < range[0]) {res.add(item);continue;}// 2 不相交,当前遍历节点start比输入的end大,在当前节点item前插入新节点,然后中止插入流程// 新增区间 = [1,3)// 遍历节点item = [6,8)if (item[0] > range[1]) {if (!hadInsert) {res.add(range);hadInsert = true;}res.add(item);continue;}// 3 以下是相交的情况// 3.1 新增区间完全包含覆盖遍历的节点item区间,丢弃或移除遍历节点// 新增区间 = [5,10)// 遍历节点item = [6,8)if (item[0] > range[0] && item[1] < range[1]) {continue;}// 3.2 新增区间前半部分与遍历的节点item相交,扩展新增区间start的范围至item[0]// 新增区间(原来) = [5,10)// 遍历节点item = [4, 6)// 新增区间(更新后) = [4,10)if (item[0] < range[0]) {range[0] = item[0];}// 3.3 新增区间后半部分与遍历的节点item相交,扩充新增区间end的范围至item[1]// 新增区间(原来) = [5,10)// 遍历节点item = [8, 12)// 新增区间(更新后) = [5,12)if (item[1] > range[1]) {range[1] = item[1];}}// 4 边界处理,可能需要把新增区间插入到结果列表中int[] last = res.size() == 0 ? range : res.get(res.size() - 1);if (res.size() == 0 || last[1] < range[0]) {res.add(range);}intervals = res;}void remove(int start, int end) {remove(new int[]{start, end});}/*** 从区间列表中移除一个区间** @param range 移除区间*/void remove(int[] range) {// 参数检查if (!checkParams(range)) {return;}// 原来的区间为空if (intervals.isEmpty()) {return;}// 存储新增&合并后的结果ArrayList<int[]> res = new ArrayList<>();for (int[] item : intervals) {// 1 不相交,直接加入到结果集中// 移除区间range = [10,12)// 遍历节点item = [6,8) 或 [14,15)if (range[1] <= item[0] || range[0] >= item[1]) {res.add(item);continue;}// 2 以下是相交的情况// 2.1 完全移除:移除区间range完全包含或覆盖遍历的节点item区间// 移除区间range = [5,10)// 遍历节点item = [6,8)if (range[0] <= item[0] && range[1] >= item[1]) {continue;}// 移除部分区间if (range[0] <= item[1]) {if (range[1] >= item[1]) {// 2.2 移除后部分:移除区间range前部与遍历的节点item后部相交,缩短遍历节点item的end范围至range[0]// 移除区间range =      [5,10)// 遍历节点item =       [4,6)// 遍历节点item(更新后) = [4,5)item[1] = range[0];res.add(item);} else {// 2.3 移除中间部分:原来区间拆分成[item[0], range[0])与[range[1], item[1]) 2部分// 移除区间range =      [5,10)// 遍历节点item =          [4,10)// 遍历节点item(更新后) =   [7,8)// 遍历节点拆分成2部分 =     [4,7) [8,10)if (range[0] > item[0]) {res.add(new int[]{item[0], range[0]});}res.add(new int[]{range[1], item[1]});}continue;}// 2.4 移除前部分:移除区间range后部分与遍历的节点item前部相交,缩短遍历节点start范围至range[1]// 移除区间range =      [5,10)// 遍历节点item =       [8,12)// 遍历节点item(更新后)= [10,12)if (range[1] > item[0]) {item[0] = range[1];res.add(item);}}intervals = res;}/*** 把区间列表转换成字符串** @return string*/@Overridepublic String toString() {StringBuilder builder = new StringBuilder();if (intervals.isEmpty()) {return builder.toString();}for (int i = 0; i < intervals.size(); i++) {int[] item = intervals.get(i);// 非第1个元素前面需要加1个空格if (i >= 1) {builder.append(BLANK);}builder.append(LEFT).append(item[0]).append(FLAG).append(item[1]).append(RIGHT);}return builder.toString();}/*** 参数校验** @param range 数组区间* @return boolean true=校验通过,false=校验不通过*/private boolean checkParams(int[] range) {// 参数及长度核验if (range == null || range.length < 2) {return false;}// 参数值核验return range[0] <= range[1];}
}

相关文章:

整数数组区间的插入与删除

相似题参考&#xff1a; 56. Merge Intervals - 力扣&#xff08;LeetCode&#xff09;合并区间 57. 插入区间 - 力扣&#xff08;LeetCode&#xff09; 1272. 删除区间 package Jerry;import org.junit.Assert; import org.junit.Test;import java.util.ArrayList; import…...

Git标签

Git 中的标签&#xff0c;指的是某个分支某个特定时间点的状态(静态)。通过标签&#xff0c;可以很方便的切换到标记时的状态。 比较有代表性的是人们会使用这个功能来标记发布结点 (v1.0、v1.2等)。 下面是myatis-plus的标签: 1 标签相关命令 命令作用git tag查看标签&…...

BarCodeWiz ActiveX Control Crack

BarCodeWiz ActiveX Control Crack BarcodeWiz ActiveX Control–只需单击按钮即可将所有基本条形码类型添加到Microsoft Office中。在Microsoft Word中&#xff0c;创建单独的条形码、标签页或合并文档。在Microsoft Excel中&#xff0c;选择单元格范围并自动将每个单元格转换…...

mysql高版本(8.0+)group_by报错的处理方法

mysql高版本8.0 group_by报错的处理方法 1. 原因2. 处理方法2.1 临时方法,重启后失效2.2 修改配置my.ini文件 1. 原因 这个错误一般发生在mysql 5.7以及 5.7以上的版本中&#xff0c;其原因是mysql的默认配置中,sql_mode“ONLY_FULL_GROUP_BY” 这个配置严格执行了 ‘SQL92标准…...

Java 下载压缩zip

Java压缩zip /*** 下载压缩包** param instId 实例id* param response 响应* author 梁伟浩* date 2023-08-21*/GetMapping("/downloadZip")ApiOperation(value "下载压缩包")ApiImplicitParam(name "instId", value "实例id", r…...

GTK3实现自定义列表

使用gtk,如果想自己定义列表,思路可以将每个列表项作为一个hbox,整个列表是一个vbox。通过对容器动态的添加删除,实现列表操作,同时添加任何自己所需要的控件。 下面的例子是实现一个显示图片、按钮和进度条的列表,并且进行上移下移,具有添加和删除列表项功能但没有演示…...

Go语言基础之数组

Array(数组) 数组是同一种数据类型元素的集合。 在Go语言中&#xff0c;数组从声明时就确定&#xff0c;使用时可以修改数组成员&#xff0c;但是数组大小不可变化。 基本语法&#xff1a; // 定义一个长度为3元素类型为int的数组a var a [3]int数组定义&#xff1a; var 数…...

信息安全从业者考试认证大全

证书是IT从业者知识水平能力的一个体现&#xff0c;考证同时也是拓展自身知识的一个方法。近年来&#xff0c;安全行业风生水起&#xff0c;各种认证层出不穷&#xff0c;眼花缭乱。这里不对任何一个证书做评价&#xff0c;只是做出介绍&#xff0c;在国内&#xff0c;对任何事…...

详解react 15~18新增特性

React 15.x 版本的新增特性&#xff1a; 创建组件类&#xff1a;在 React 15 中&#xff0c;可以使用 createClass 方法来创建组件类。这个方法允许你定义组件的生命周期方法、渲染函数以及其他功能。 PropTypes&#xff1a;React 15 引入了 PropTypes&#xff0c;它是一种用于…...

SpringBoot整合FFmpeg进行视频分片上传(Linux)

SpringBoot整合FFmpeg进行视频分片上传&#xff08;Linux&#xff09; 上传的核心思路&#xff1a; 1.将文件按一定的分割规则&#xff08;静态或动态设定&#xff0c;如手动设置20M为一个分片&#xff09;&#xff0c;用slice分割成多个数据块。 2.为每个文件生成一个唯一标识…...

eNSP综合小实验:VRRP、MSTP、Eth-Trunk、NAT、DHCP等技术应用

完成下图要求&#xff1a; 拓扑图&#xff1a; 配置命令&#xff1a; 由于交换机日志太多不便于复制&#xff0c;所以就复制命令。大概步骤如下&#xff1a; 第一步先分配IP地址&#xff0c;在sw1和sw2上创建VLAN100用于e0/0/3口配IP&#xff0c;在sw1、sw2、sw3、sw4上创建VL…...

正中优配:尾盘拉升的股票第二天的走势?

尾盘拉升是指买卖日快结束时股票价格呈现上涨的状况。关于许多投资者来说&#xff0c;这一般是好事情&#xff0c;因为它可认为他们带来更高的收益。但是&#xff0c;人们常常会问尾盘拉升的股票第二天的走势怎么。本文将从多个角度进行剖析。 首要&#xff0c;咱们需求认识到这…...

ios小组件报错:Please adopt containerBackground API

iOS 17 小组件报错:Please adopt containerBackground API 使用下面的方法解决了: 代码: extension View {func widgetBackground(_ backgroundView: some View) -> some View {if #available(iOSApplicationExtension 17.0, *) {return containerBackground(for: .wi…...

基于AWS的3D模型搜索服务实现

3D模型广泛应用于计算机游戏、电影、工程、零售业、广告等许多领域。市场上有很多制作3D模型的工具&#xff0c;但几乎没有工具可以直观地搜索3D模型数据库以找到类似的3D模型 因为开发好的 3D 模型搜索工具非常具有挑战性。 它需要复杂的计算和 AI/ML 框架来创建模型描述符并提…...

pycharm远程连接docker容器

pycharm远程连接docker容器 1.根据镜像创建容器2.进入容器3.修改容器的root密码4. 容器安装openssh-server和openssh-client5.修改SSH配置文件6.重启ssh服务7. 退出测试8.配置pycharm并连接docker容器9. 选择docker环境 1.根据镜像创建容器 sudo docker run -itd --nameconn_t…...

开源全球地理空间数据可视化框架——Cesium学习(2023.8.21)

Cesium学习 2023.8.21 1、Cesium简介1.1 Github上的Cesium 2、Cesium下载安装使用2.1 方式一&#xff1a;页面在线引用2.2 方式二&#xff1a;页面离线使用2.3 方式三&#xff1a;完整项目使用 3、CesiumJS学习教程&#xff08;快速上手 API文档&#xff09;3、Cesium官方示例…...

RT-Thread学习日记——点亮LED

最近开始接触RT-Thread&#xff0c;后面会单独建立专栏以此记录我的学习过程&#xff0c;如果能给你的学习提供参考&#xff0c;本人倍感荣幸。 学习工具&#xff1a;正点原子战舰开发板 一、、点亮LED 在RT-Thread的配置项里搜索LED可以看到和LED相关的很多内容&#xff0c…...

粘包问题(TCP面向字节流批量发送数据导致)

粘包问题出现的原因 由于TCP协议网络传输数据的基本单位是字节流&#xff0c;所以当应用程序收到了传输的数据时&#xff0c;看到的是一连串的字节数据&#xff0c;而TCP协议网络传输数据有滑动窗口的机制&#xff08;核心就是批量传输数据&#xff0c;推荐看TCP中窗口和滑动窗…...

selenium Chrome驱动下载地址

Chrome驱动官方最新版下载地址:https://googlechromelabs.github.io/chrome-for-testing/ 有稳定版&#xff0c;开发版等版本可以选择下载 选择 操作系统复制下载链接直接下载...

Linux命令200例:tar命令主要用于创建、查看和提取归档文件(常用)

&#x1f3c6;作者简介&#xff0c;黑夜开发者&#xff0c;全栈领域新星创作者✌。CSDN专家博主&#xff0c;阿里云社区专家博主&#xff0c;2023年6月csdn上海赛道top4。 &#x1f3c6;数年电商行业从业经验&#xff0c;历任核心研发工程师&#xff0c;项目技术负责人。 &…...

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…...

AI-调查研究-01-正念冥想有用吗?对健康的影响及科学指南

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; &#x1f680; AI篇持续更新中&#xff01;&#xff08;长期更新&#xff09; 目前2025年06月05日更新到&#xff1a; AI炼丹日志-28 - Aud…...

基于ASP.NET+ SQL Server实现(Web)医院信息管理系统

医院信息管理系统 1. 课程设计内容 在 visual studio 2017 平台上&#xff0c;开发一个“医院信息管理系统”Web 程序。 2. 课程设计目的 综合运用 c#.net 知识&#xff0c;在 vs 2017 平台上&#xff0c;进行 ASP.NET 应用程序和简易网站的开发&#xff1b;初步熟悉开发一…...

可靠性+灵活性:电力载波技术在楼宇自控中的核心价值

可靠性灵活性&#xff1a;电力载波技术在楼宇自控中的核心价值 在智能楼宇的自动化控制中&#xff0c;电力载波技术&#xff08;PLC&#xff09;凭借其独特的优势&#xff0c;正成为构建高效、稳定、灵活系统的核心解决方案。它利用现有电力线路传输数据&#xff0c;无需额外布…...

【Go语言基础【13】】函数、闭包、方法

文章目录 零、概述一、函数基础1、函数基础概念2、参数传递机制3、返回值特性3.1. 多返回值3.2. 命名返回值3.3. 错误处理 二、函数类型与高阶函数1. 函数类型定义2. 高阶函数&#xff08;函数作为参数、返回值&#xff09; 三、匿名函数与闭包1. 匿名函数&#xff08;Lambda函…...

C/C++ 中附加包含目录、附加库目录与附加依赖项详解

在 C/C 编程的编译和链接过程中&#xff0c;附加包含目录、附加库目录和附加依赖项是三个至关重要的设置&#xff0c;它们相互配合&#xff0c;确保程序能够正确引用外部资源并顺利构建。虽然在学习过程中&#xff0c;这些概念容易让人混淆&#xff0c;但深入理解它们的作用和联…...

c++第七天 继承与派生2

这一篇文章主要内容是 派生类构造函数与析构函数 在派生类中重写基类成员 以及多继承 第一部分&#xff1a;派生类构造函数与析构函数 当创建一个派生类对象时&#xff0c;基类成员是如何初始化的&#xff1f; 1.当派生类对象创建的时候&#xff0c;基类成员的初始化顺序 …...

DeepSeek源码深度解析 × 华为仓颉语言编程精粹——从MoE架构到全场景开发生态

前言 在人工智能技术飞速发展的今天&#xff0c;深度学习与大模型技术已成为推动行业变革的核心驱动力&#xff0c;而高效、灵活的开发工具与编程语言则为技术创新提供了重要支撑。本书以两大前沿技术领域为核心&#xff0c;系统性地呈现了两部深度技术著作的精华&#xff1a;…...

Linux 下 DMA 内存映射浅析

序 系统 I/O 设备驱动程序通常调用其特定子系统的接口为 DMA 分配内存&#xff0c;但最终会调到 DMA 子系统的dma_alloc_coherent()/dma_alloc_attrs() 等接口。 关于 dma_alloc_coherent 接口详细的代码讲解、调用流程&#xff0c;可以参考这篇文章&#xff0c;我觉得写的非常…...

一些实用的chrome扩展0x01

简介 浏览器扩展程序有助于自动化任务、查找隐藏的漏洞、隐藏自身痕迹。以下列出了一些必备扩展程序&#xff0c;无论是测试应用程序、搜寻漏洞还是收集情报&#xff0c;它们都能提升工作流程。 FoxyProxy 代理管理工具&#xff0c;此扩展简化了使用代理&#xff08;如 Burp…...