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

相似题参考:

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];}
}

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

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

相关文章

Ubuntu20.04下安装搜狗输入法Linux版

Ubuntu20.04下安装搜狗输入法Linux版 参考搜狗输入法的官网安装指南&#xff1b; 第一步&#xff1a;打开搜狗输入法官网&#xff1b; https://shurufa.sogou.com/ 点击X86_64后将会自动跳转到搜狗输入法的安装指南中&#xff1b; 安装指南 Ubuntu搜狗输入法安装指南 搜狗…

Linux的Man Page知识记录

Man&#xff08;short for manual&#xff09; Page是Unix和Linux操作系统中的一个重要文档&#xff0c;提供命令、函数、系统调用等的详细介绍和使用说明。它是以纯文本的形式出现&#xff0c;通常在终端&#xff08;terminal&#xff09;中使用man命令访问。Man Page按照章节…

微信小程序【构建npm】使用记录

:: 问题 使用原生微信小程序开发时&#xff0c;通过官方 typescript 模板构建的小程序无法正确执行 构建npm 成功&#xff0c;从而导致我想通过 npm 安装并使用第三方库出现问题 :: 开发环境&#xff08;可参照&#xff09; 设备&#xff1a;macOS Ventura 13.0 微信开发者工…

elementui的el-tabs标签页样式修改

一、官网样式&#xff1a; 二、修改样式 1.去掉下划线 效果&#xff1a; 代码: /* 去掉tabs标签栏下的下划线 */ ::v-deep .el-tabs__nav-wrap::after {position: static !important;/* background-color: #fff; */ } 2.改变下划线颜色 效果&#xff1a; 代码&#xff1a;…

Docker网络-探索容器网络如何相互通信

当今世界&#xff0c;企业热衷于容器化&#xff0c;这需要强大的网络技能来正确配置容器架构&#xff0c;因此引入了 Docker Networking 的概念。Docker 是一种容器化平台&#xff0c;允许您在独立、轻量级的容器中运行应用程序和服务。Docker 提供了一套强大的网络功能&#x…

QNAP(威联通)NAS外远程访问指南,免费内网穿透工具的应用和配置指导——“cpolar内网穿透”

文章目录 前言1. 威联通安装cpolar内网穿透2. 内网穿透2.1 创建隧道2.2 测试公网远程访问 3. 配置固定二级子域名3.1 保留二级子域名3.2 配置二级子域名 4. 使用固定二级子域名远程访问 前言 购入威联通NAS后&#xff0c;很多用户对于如何在外在公网环境下的远程访问威联通NAS…

软件工程(六) 面向对象分析(OOA)之UML图特点

1、UML 面向对象分析里面有一个非常重要的工具叫UML,UML不仅在工作中非常重要,在考试当中也是非常重要的,即作为上午综合体,又大概率又会出现在下午的案例分析中,作为一个25分的大题。 UML叫做统一建模语言,它主要用于需求分析和软件的设计,来做一些模型的制作。比如我…

git查看和修改项目远程仓库地址

git查看和修改项目远程仓库地址 一、背景 项目代码仓库迁移&#xff0c;需要本地更新远程仓库地址,进行代码同步与提交。 二、查看项目的远程仓库地址 # 查看远程地址 git remote -v # 查看远程仓库信息&#xff08;分支、地址等&#xff09; git remote show origin三、修…

QT之应用程序执行脚本

简介 ● Qt中的类QProcess支持在程序中另外开辟线程 ● 其中start方法支持以字符串为参数执行命令 以Linux平台为例&#xff1a; 方式一&#xff08;后台执行&#xff09; /// /// \brief MainWindow::cmdLine run a linux command with string format in the bash /// \pa…

金九银十面试题之《语言特性》

&#x1f42e;&#x1f42e;&#x1f42e; 辛苦牛&#xff0c;掌握主流技术栈&#xff0c;包括前端后端&#xff0c;已经7年时间&#xff0c;曾在税务机关从事开发工作&#xff0c;目前在国企任职。希望通过自己的不断分享&#xff0c;可以帮助各位想或者已经走在这条路上的朋友…

深度学习数据预处理

参考文章&#xff1a;深度学习中的数据预处理方法总结 在深度学习中&#xff0c;数据预处理&#xff08;preprocessing&#xff09;的重要性体现在以下几个方面&#xff1a; 1、数据质量&#xff1a; 原始数据通常包含错误、缺失值、异常值和噪声。预处理能够检测和处理这些问…

Qt 自定义菜单、右键菜单

在接触Qt这段时间以来&#xff0c;经常遇到菜单项的问题&#xff08;右键菜单、托盘菜单、按钮菜单等&#xff09;&#xff0c;QMenu用于菜单栏,上下文菜单,弹出菜单等&#xff0c;利用QMenuQAction就可以达到效果&#xff01; 右键菜单实现&#xff1a;通过重写contextMenuEv…

【redis问题】Caused by: io.netty.channel

遇到的问题&#xff1a; 在使用 RedisTemplate 连接 Redis 进行操作的时候&#xff0c;发生了如下报错&#xff1a; 测试代码为&#xff1a; 配置文件&#xff1a; 问题根源&#xff1a; redis没有添加端口映射解决方案&#xff1a; 删除原来的redis容器&#xff0c;添加新…

stm32之11.USART串口通信

可以添加上拉电阻&#xff0c;但会增加功耗&#xff0c;传输距离变长 要添加库函数USART 官方参考文档说明书位置 ALT&#xff0b;左键可实现整体删除&#xff08;如下图&#xff09; 输出模式第三种模式AF ---------------------- 源码 远程控制pc端 #include <stm32f4x…

springboot服务端接口外网远程调试,并实现HTTP服务监听

文章目录 前言1. 本地环境搭建1.1 环境参数1.2 搭建springboot服务项目 2. 内网穿透2.1 安装配置cpolar内网穿透2.1.1 windows系统2.1.2 linux系统 2.2 创建隧道映射本地端口2.3 测试公网地址 3. 固定公网地址3.1 保留一个二级子域名3.2 配置二级子域名3.2 测试使用固定公网地址…

MDK 5.xx.0 + STM32F10x 笔记

天才脑袋比不上烂笔头, 写给自己看, 自用资料。 安装MDK STM32环境 Download MDK安装 MDK -> c:\keil_v5 用默认路径下载 ARMCC V5.06 Update 7 (build960) <- 长期稳定支持版本安装至 c:\keil_v5\arm\ARMCC开启 uVision.设定 预设编译程序版本 : V5.06 Update 7 (bui…

java 版本企业招标投标管理系统源码+功能描述+tbms+及时准确+全程电子化 tbms

​ 功能描述 1、门户管理&#xff1a;所有用户可在门户页面查看所有的公告信息及相关的通知信息。主要板块包含&#xff1a;招标公告、非招标公告、系统通知、政策法规。 2、立项管理&#xff1a;企业用户可对需要采购的项目进行立项申请&#xff0c;并提交审批&#xff0c;查…

数学系硕士研究生的科研过程——PDE约束下含参优化控制问题的深度学习算法

笔者今天上午收到了之前北大课题组老板的通知&#xff0c;得知研究生期间和学长合作的论文终于被siam接收&#xff0c;终于为自己研究生涯画上了一个句号。这里打算分享一下个人的科研过程以及这篇论文的工作&#xff0c;即将读研或者打算读研的同学或许可以从中获得益处。论文…

【数据结构】 队列(Queue)与队列的模拟实现

文章目录 &#x1f340;队列(Queue)的概念&#x1f38b;队列的使用&#x1f38d;队列的模拟实现&#x1f6a9;创建队列&#x1f6a9;入队列&#x1f6a9;出队列&#x1f6a9;获取队头元素&#x1f6a9;获取队列长度&#x1f6a9;判断是否为空&#x1f6a9;完整代码 &#x1f33…

软件工程(十三) 设计模式之结构型设计模式(一)

前面我们记录了创建型设计模式,知道了通过各种模式去创建和管理我们的对象。但是除了对象的创建,我们还有一些结构型的模式。 1、适配器模式(Adapter) 简要说明 将一个类的接口转换为用户希望得到的另一个接口。它使原本不相同的接口得以协同工作。 速记关键字 转换接…