Acwing803区间合并

题目

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

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

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

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

输入格式

第一行包含整数 n

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

输出格式

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

数据范围

1≤n≤100000 −109≤li≤ri≤109

输入样例:

复制代码
5
1 2
2 4
5 6
7 8
7 9

输出样例:

复制代码
3

代码和思路

  1. 读取输入的数量 n。

  2. 创建 Pair 类数组 p,用于存储每个区间的左右边界。

  3. 读取每个区间的左右边界,并将其存储到 Pair 数组中。

  4. 初始化最终结果 ans 为 1,将 Pair 数组按照左边界从小到大排序。

  5. 初始化当前区间的左右边界为 p[0].x 和 p[0].y。

  6. 遍历每个区间:

    • 如果当前区间的左边界小于等于当前区间的右边界,则将当前区间的右边界更新为两者的最大值。
    • 否则,将结果 ans 加 1,并更新当前区间的左右边界。
  7. 输出结果 ans

java 复制代码
import java.util.Arrays;
import java.util.Scanner;

public class Main {
    static int n;

    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        
        // 读取输入的数量 n
        n = in.nextInt();
        
        // 创建 Pair 数组 p,用于存储区间的左右边界
        Pair[] p = new Pair[n + 1];
        
        // 读取每个区间的左右边界,并将其存储到 Pair 数组中
        for (int i = 0; i < n; i++) {
            int l = in.nextInt();
            int r = in.nextInt();
            p[i] = new Pair(l, r);
        }

        // 初始化最终结果 ans 为 1,将 Pair 数组按照左边界从小到大排序
        int ans = 1;
        Arrays.sort(p, 0, n);
        
        // 初始化当前区间的左右边界为 p[0].x 和 p[0].y
        int l = p[0].x, r = p[0].y;
        
        // 遍历每个区间
        for (int i = 1; i < n; i++) {
            // 如果当前区间的左边界小于等于当前区间的右边界,则将当前区间的右边界更新为两者的最大值
            if (p[i].x <= r) {
                r = Math.max(r, p[i].y);
            } else { // 否则,将结果 ans 加 1,并更新当前区间的左右边界
                ans++;
                l = p[i].x;
                r = p[i].y;
            }
        }
        
        // 输出结果 ans
        System.out.println(ans);
    }

    // 自定义 Pair 类,用于存储区间的左右边界,并实现 Comparable 接口用于排序
    public static class Pair implements Comparable<Pair> {
        int x, y;

        public Pair(int x, int y) {
            this.x = x;
            this.y = y;
        }

        // 按照左边界从小到大排序
        @Override
        public int compareTo(Pair o) {
            return Integer.compare(this.x, o.x);
        }
    }
}
相关推荐
CappuccinoRose17 分钟前
回溯法 - 软考备战(四十三)
算法·排列组合·路径·n皇后·子集·解数独·岛屿
AC赳赳老秦20 分钟前
OpenClaw进阶技巧:批量修改文件内容、替换关键词,解放双手
java·linux·人工智能·python·算法·测试用例·openclaw
Robot_Nav1 小时前
Shape-Aware MPPI(SA MPPI)算法:基于RC-ESDF的任意形状机器人实时轨迹优化
算法·机器人·sa-mppi
小O的算法实验室2 小时前
2026年ESWA,自适应基于排序的协同进化学习粒子群算法+边缘计算服务器部署,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
cpp_25012 小时前
P1832 A+B Problem(再升级)
数据结构·c++·算法·动态规划·题解·洛谷·背包dp
꧁细听勿语情꧂3 小时前
合并两个有序表、判断链表的回文结构、相交链表、环的链表一和二
c语言·开发语言·数据结构·算法
木井巳3 小时前
【递归算法】解数独
java·算法·leetcode·决策树·深度优先·剪枝
大肥羊学校懒羊羊3 小时前
完数与盈数的计算题解
数据结构·c++·算法
阿Y加油吧3 小时前
算法实战笔记:LeetCode 31 下一个排列 & 287 寻找重复数
笔记·算法·leetcode
穿条秋裤到处跑3 小时前
每日一道leetcode(2026.04.24):距离原点最远的点
算法·leetcode·职场和发展