当前位置:首页 > 题解目录 > 正文内容

【题解】区间合并

亿万年的星光8个月前 (05-30)题解目录577

【题目描述】

给定n个闭区间[ai,bi],其中i=1,2,...n。任意两个相邻或相交或相邻的闭区间可以合并为一个闭区间。例如,[1,2]和[2,3]可以合并为[1,3]。

[1,3]和[2,4]可以合并为[1,4],但是[1,2]和[3,4]不可以合并。

我们的任务是判断这些区间是否可以最终合并为一个闭区间,如果可以,则将这个闭区间输出,否则输出no

【输入描述】

第一行为一个整数n,3<n<50000。表示输入区间的数量。

之后n行,在第i行上(1<=i<=n),为两个整数ai和bi,整数之间用一个空格分隔,表示区间[ai,bi] 

(其中1<=ai<=bi<=10000)

【输出描述】

输出一行,如果这些区间最终可以合并为一个闭区间,输出这些闭区间的左右边界,用单个空格隔开;否则输出no

【样例输入】

5
5 6
1 5
10 10
6 9
8 10

【样例输出】

1 10


【题目分析】

排序区间:首先将所有区间按照左端点从小到大排序。按顺序合并区间。


贪心合并:

初始化 merged_interval 为第一个区间。

遍历后续区间,如果当前区间与 merged相交或相邻,则更新 merged 的右端点为两者的最大值。

如果不能合并,则直接返回 no。

检查是否合并完成:如果最终 merged 包含了所有区间,则输出它;否则输出 no。



【参考答案】

#include <bits/stdc++.h>
using namespace std;
// 定义区间结构体
struct Interval {
    int start;
    int end;
};
Interval a[100000];
bool cmp(Interval a,Interval b){
	return a.start<b.start;
}

int main() {
    int n;
    cin >> n;
    // 输入区间
    for (int i = 0; i < n; i++) {
        cin >> a[i].start >> a[i].end;
    }
    sort(a, a+n,cmp);
    // 初始化合并区间
    Interval merged = a[0];
    bool canMergeAll = true;
    // 尝试合并
    for (int i = 1; i < n; i++) {
        if (a[i].start <= merged.end) {
            // 更新右端点
            if (a[i].end > merged.end) {
                merged.end = a[i].end;
            }
        } else {
            canMergeAll = false;
            break;
        }
    }

    // 输出结果
    if (canMergeAll) {
        cout << merged.start << " " << merged.end << endl;
    } else {
        cout << "no" << endl;
    }

    return 0;
}


    扫描二维码推送至手机访问。

    版权声明:本文由青少年编程知识记录发布,如需转载请注明出处。

    分享给朋友:

    相关文章

    【题解】流感传染

    【题目描述】有一批易感人群住在网格状的宿舍区内,宿舍区为n\*n的矩阵,每个格点为一个房间,房间里可能住人,也可能空着。在第一天,有些房间里的人得了流感,以后每天,得流感的人会使其邻居传染上流感,(已...

    【题解】走出迷宫的最少步数

    【题目描述】一个迷宫由R行C列格子组成,有的格子里有障碍物,不能走;有的格子是空地,可以走。给定一个迷宫,求从左上角走到右下角最少需要走多少步(数据保证一定能走到)。只能在水平方向或垂直方向走,不能斜...

    【题解】增添战斗力

    【题目描述】大战即将来临,杰洛特需要为自己增添战斗力,广袤的大陆有诸多豪杰,正好可以为杰洛特所用    杰洛特分别有两处地方n1,n2需要豪杰的战斗力    一...

    【题解】最大数问题

    【题目描述】输入若干个整数。输出其中的最大数【输入描述】若干个整数。【输出描述】其中的最大数。【样例输入】1 2 5 7 8 6 1&nbs...

    【题解】求逆序对个数

    【题目描述】有一实数序列A[1]、A[2] 、A[3] 、……A[n-1] 、A[n] (n<10000),若i<j,并且A[i]>A[j],则称A[i]与A[j]构成了一个逆序对,...

    【题解】背包问题3

    【题目描述】完全背包定义有N种物品和一个容量为V的背包,每种物品都有无限件可用。第i种物品的体积是c,价值是w。求解将哪些物品装入背包可使这些物品的体积总和不超过背包容量,且价值总和最大。本题要求是背...