博客
关于我
AcWing 908. 最大不相交区间数量(贪心:同区间选点)
阅读量:355 次
发布时间:2019-03-04

本文共 1689 字,大约阅读时间需要 5 分钟。

为了解决这个问题,我们需要找到数轴上最多的不相交区间。我们可以使用贪心算法来解决这个问题,这种算法通常能找到最优解,尤其是在区间调度问题中。

方法思路

  • 问题分析:我们需要选择尽可能多的区间,使得这些区间之间互不相交(包括端点)。如果两个区间的端点相同,它们也不能同时被选中。
  • 贪心算法:贪心算法的基本思想是总是选择当前最优解,以期望得到全局最优解。在区间调度问题中,我们可以通过排序区间来实现这一点。
  • 排序策略:首先将区间按照左端点排序,如果左端点相同,则按右端点排序,右端点较大的排在前面。这样可以确保我们总是选择覆盖最长范围的区间,从而为后面的选择留下更多空间。
  • 遍历检查:初始化当前区间的右端点为负无穷,遍历每个区间,如果当前区间的左端点大于当前右端点,则选中该区间,并更新当前右端点。
  • 解决代码

    import java.io.BufferedReader;
    import java.io.InputStreamReader;
    import java.util.Arrays;
    public class Main {
    static int n = 0, N = 100010;
    public static void main(String[] args) throws Exception {
    BufferedReader buf = new BufferedReader(new InputStreamReader(System.in));
    n = Integer.valueOf(buf.readLine());
    int[][] nums = new int[n][2];
    int t = 0;
    while (n-- != 0) {
    String[] info = buf.readLine().split(" ");
    int a = Integer.valueOf(info[0]);
    int b = Integer.valueOf(info[1]);
    nums[t][0] = a;
    nums[t][1] = b;
    t++;
    }
    Arrays.sort(nums, (a, b) -> {
    if (a[0] != b[0]) {
    return Integer.compare(a[0], b[0]);
    } else {
    return Integer.compare(b[1], a[1]);
    }
    });
    int right = -Integer.MAX_VALUE;
    int cnt = 0;
    for (int i = 0; i < nums.length; i++) {
    if (nums[i][0] > right) {
    cnt++;
    right = nums[i][1];
    }
    }
    System.out.print(cnt);
    }
    }

    代码解释

  • 读取输入:使用 BufferedReader 读取输入数据,解析区间端点。
  • 排序区间:将区间按照左端点排序,如果左端点相同,则按右端点排序,右端点较大的排在前面。
  • 遍历区间:初始化当前区间右端点为负无穷,遍历每个区间,如果当前区间的左端点大于当前右端点,则选中该区间,并更新当前右端点。
  • 输出结果:输出选中的区间数量。
  • 这种方法确保了我们总是选择最优的区间,从而得到最多的不相交区间数量。

    转载地址:http://vyre.baihongyu.com/

    你可能感兴趣的文章
    nodejs 读取xlsx文件内容
    查看>>
    nodejs 运行CMD命令
    查看>>
    Nodejs+Express+Mysql实现简单用户管理增删改查
    查看>>
    nodejs+nginx获取真实ip
    查看>>
    nodejs-mime类型
    查看>>
    NodeJs——(11)控制权转移next
    查看>>
    NodeJS、NPM安装配置步骤(windows版本)
    查看>>
    NodeJS、NPM安装配置步骤(windows版本)
    查看>>
    nodejs下的express安装
    查看>>
    nodejs与javascript中的aes加密
    查看>>
    nodejs中Express 路由统一设置缓存的小技巧
    查看>>
    nodejs中express的使用
    查看>>
    Nodejs中搭建一个静态Web服务器,通过读取文件获取响应类型
    查看>>
    Nodejs中的fs模块的使用
    查看>>
    NodeJS使用淘宝npm镜像站的各种姿势
    查看>>
    NodeJs入门知识
    查看>>
    nodejs包管理工具对比:npm、Yarn、cnpm、npx
    查看>>
    NodeJs单元测试之 API性能测试
    查看>>
    nodejs图片转换字节保存
    查看>>
    nodejs在Liunx上的部署生产方式-PM2
    查看>>