C++ 区间合并 算法(详解) + 例题

1、定义

  • 把所有,有交集的区间合并

  • 图解:

      

2、实现

  • 步骤如下:
    • 1、首先按照每个区间左端点排序

    • 2、扫描 所有区间,进行区间合并

    • 上述第二条,可以理解为:拿出一个区间去跟它后面的所有的区间去进行合并(因为我们先拿出左端点去排序,所以不用害怕后面的区间会小于什么的)。

  • 图解:

      

· 代码模板: 

//将所有存在交集的区间进行合并
void merge(vector<PII> &segs)
{vector<PII> res;sort(segs.begin(),segs.end());int st = -2e9,ed = -2e9;for(auto seg : segs){if(ed < seg.first){if(st!=-2e9) res.push_back({st,ed});st = seg.first,ed = seg.second;}else ed = max(ed,seg.second);}if(st!=-2e9) res.push_back({st,ed});segs = res;
}

3、例题:803. 区间合并 - AcWing题库

  • 给定 n个区间 [li ri],要求合并所有有交集的区间。

    注意如果在端点处相交,也算有交集。

    输出合并完成后的区间个数。

    例如: [1,3] 和 [2,6] 可以合并为一个区间 [1,6]。

    输入格式

    第一行包含整数 n。

    接下来 n 行,每行包含两个整数 l 和 r。

    输出格式

    共一行,包含一个整数,表示合并区间完成后的区间个数。

    数据范围

    1≤n≤100000      −10 ^ 9 ≤ li ≤ ri ≤ 10 ^ 9

  • 输入样例:
    5
    1 2
    2 4
    5 6
    7 8
    7 9
    输出样例:
    3

    图解:

        

AC代码(这里给出两种写法): 

#include<iostream>
#include<algorithm>
#include<cmath>
#include<vector>
#include<utility>using namespace std;
typedef pair<int,int> PII;
const int N = 100010;
vector<PII> segs;
int n;//区间合并
void merge(vector<PII> &segs)
{vector<PII> res;//用来存储//按区间的左端点来进行排序,然后再按照第二个排序(pair很像)sort(segs.begin(),segs.end());将st(start)和ed(end)初始化为负无穷,确保端点一定在左面int st = -2e9, ed = -2e9;for(auto seg : segs){//如果比较区间的左端点不在当前区间中if(ed < seg.first){//判断一下是否更新 新的当前区间(以防第一次更新)if(st!=-2e9) res.push_back({st,ed});st = seg.first,ed = seg.second;//更新区间,变成当前区间}//如果比较区间的左端点在区间中更新一下最大的右端点else ed = max(ed,seg.second); }//看一下,最后一个元素是否被合并if(st!=-2e9) res.push_back({st,ed});segs = res;
}int main()
{cin >> n;//存入坐标for(int i=0;i<n;i++){int l,r;cin >> l >> r;segs.push_back({l,r});}//区间合并merge(segs);cout << segs.size() << endl;return 0;
}
第二种: 
#include<bits/stdc++.h>using namespace std;
typedef pair<int, int> PII;
vector<PII> segs;
int n,res;int main()
{cin >> n;for(int i=0;i<n;i++){int l,r;cin >> l >> r;segs.push_back({l,r});}sort(segs.begin(),segs.end());int ed = segs[0].second;for(int i=1;i<n;i++){if(ed < segs[i].first){res++;ed = segs[i].second;}else ed = max(ed,segs[i].second);}cout << res + 1 << endl;return 0;
}

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

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

相关文章

Java使用企业微信

前言&#xff1a;最近接到一个需求&#xff0c;需要根据所监控设备的信息&#xff0c;在出现问题时发送企业微信进行预警。 POM依赖 <!-- 邮件 --> <dependency><groupId>com.sun.mail</groupId><artifactId>jakarta.mail</artifactId>…

202427读书笔记|《猫的自信:治愈系生活哲学绘本》——吸猫指南书,感受猫咪的柔软慵懒与治愈

202427读书笔记|《猫的自信&#xff1a;治愈系生活哲学绘本》——吸猫指南书&#xff0c;感受猫咪的柔软慵懒与治愈 《猫的自信&#xff1a;治愈系生活哲学绘本》作者林行瑞&#xff0c;治愈系小漫画绘本&#xff0c;10分钟可以读完的一本书&#xff0c;线条明媚&#xff0c;自…

莱卡云怎么样?简单测评下莱卡云韩国CN2云服务器

莱卡云服务器厂商&#xff0c;国内持证企业服务器商家&#xff0c;运作着香港、美国、韩国、镇江、日本、绍兴、枣庄、等数据中心的云服务器、独立服务器出租、设备托管、CDN等业务。今天为大家带来的是莱卡云韩国CN2服务器的详细评测&#xff0c;该云服务器的数据中心位于韩国…

HarmonyOS4.0系列——08、整合UI常用组件

HarmonyOS4.0 系列——08、UI 组件 Blank Blank 组件在横竖屏占满空余空间效果 // xxx.ets Entry Component struct BlankExample {build() {Column() {Row() {Text(Button).fontSize(18)Blank()Toggle({type: ToggleType.Switch}).margin({top: 14,bottom: 14,left: 6,righ…

电子信息产业园污水处理工艺设备需要哪些

电子信息产业园的污水处理工艺设备是保证园区环境卫生和可持续发展的关键设备之一。随着电子信息产业的发展和园区规模的扩大&#xff0c;对污水处理设备的需求也日益增长。那么&#xff0c;电子信息产业园污水处理工艺设备需要哪些呢&#xff1f;下面将从工艺设备的分类和功能…

[oeasy]python0007_ print函数_字符串_display_电传打字机_程序员的浪漫

你好世界 &#x1f94a; 回忆上次内容 上次 想输出 Hello world&#xff01;据说是程序猿的浪漫 键盘按键作用↑上一条指令↓下一条指令←光标 向左移动 一格→光标 向右移动 一格ctrl a光标 移动到开头ctrl e光标 移动到结尾 了解到 字符串 就是 给一串字符 两边加引号…

神经网络——循环神经网络(RNN)

神经网络——循环神经网络&#xff08;RNN&#xff09; 文章目录 神经网络——循环神经网络&#xff08;RNN&#xff09;一、循环神经网络&#xff08;RNN&#xff09;二、循环神经网络结构1、一对一&#xff08;One to One&#xff09;2、一对多&#xff08;One to Many&#…

云原生概念

云原生是一条使用户能&#xff1a; 1.低运维、 2.敏捷的、 3.以可扩展、可复制的方式&#xff0c; 最大化的利用”云“的能力、发挥”云“的价值的最 佳路径 云原生&#xff0c;是一条最佳路径或实践 参考&#xff1a;https://edu.aliyun.com/course/314164/lesson/7815

168基于matlab的六自由度并联摇摆台的反解控制算法

基于matlab的六自由度并联摇摆台的反解控制算法&#xff0c;stewart平台&#xff0c;配有GUI界面&#xff0c;可以自定义角度&#xff0c;杆长等参数。设定动平台位姿即能得到电机参数。程序已调通&#xff0c;可直接运行。 168 六自由度并联摇摆台 反解控制算法 (xiaohongshu.…

智慧城市与数字孪生:实现城市可持续发展的关键

一、引言 随着全球城市化进程的加速&#xff0c;城市面临着诸多挑战&#xff0c;如资源紧张、环境恶化、交通拥堵等。为了解决这些问题&#xff0c;智慧城市的概念应运而生。智慧城市利用先进的信息通信技术&#xff0c;提升城市治理水平&#xff0c;改善市民的生活质量。而数…

基于Java SSM框架实现网上拍卖系统项目【项目源码】

基于java的SSM框架实现网上拍卖系统演示 JSP技术介绍 JSP技术本身是一种脚本语言&#xff0c;但它的功能是十分强大的&#xff0c;因为它可以使用所有的JAVA类。当它与JavaBeans 类进行结合时&#xff0c;它可以使显示逻辑和内容分开&#xff0c;这就极大的方便了用户的需求。…

在springboot项目中调用openai API及我遇到的问题

这两天我在自己的网站中集成了openai API&#xff0c;引入chatgpt对话机器人&#xff0c;中途遇到了很多坑&#xff0c;记录一下。文章中会涉及一些付费工具&#xff0c;如果你有类似功能的工具&#xff0c;完全可以使用自己的。&#xff08;主要是我想澄清一下&#xff0c;我不…