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

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

给定N个闭区间[ai,bi],请你在数轴上选择若干区间,使得选中的区间之间互不相交(包括端点)。

输出可选取区间的最大数量。

输入格式

第一行包含整数N,表示区间数。

接下来N行,每行包含两个整数ai,biai,bi,表示一个区间的两个端点。

输出格式

输出一个整数,表示可选取区间的最大数量。

数据范围

1≤N≤10^5,

−10^9≤ai≤bi≤10^9输入样例:

3-1 12 43 5

输出样例:

2
import java.io.*;import java.lang.*;import java.util.*;class Main{        static int n = 0, N = 100010;    static int cnt = 1;    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)->{return a[0] - b[0];});//排序        for(int i = 1; i < t; ++i){            if(nums[i][0] > nums[i - 1][1]){                cnt++;            }else{                //选择最小右侧区间以求找到最大的重合次数,而区间合并是选择最大的右侧以求最长的覆盖范围                nums[i][1] = Math.min(nums[i][1], nums[i - 1][1]);            }        }        System.out.print(cnt);            }}

 

 

 

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

你可能感兴趣的文章
NAT技术
查看>>
NAT模式下虚拟机centOs和主机ping不通解决方法
查看>>
NAT的两种模式SNAT和DNAT,到底有啥区别?
查看>>
Navicat for MySQL 命令列 执行SQL语句 历史日志
查看>>
Navicat for MySQL 查看BLOB字段内容
查看>>
Navicat Premium 12 卸载和注册表的删除
查看>>
navicat 系列软件一点击菜单栏就闪退
查看>>
navicat 连接远程mysql
查看>>
Navicat下载和破解以及使用
查看>>
Navicat可视化界面导入SQL文件生成数据库表
查看>>
Neat Stuff to Do in List Controls Using Custom Draw
查看>>
NeHe OpenGL教程 第四十四课:3D光晕
查看>>
neo4j图形数据库Java应用
查看>>
Neo4j安装部署及使用
查看>>
Neo4j电影关系图Cypher
查看>>
Neo4j的安装与使用
查看>>
Neo4j(2):环境搭建
查看>>
Neo私链
查看>>
Nerves 项目教程
查看>>
nessus快速安装使用指南(非常详细)零基础入门到精通,收藏这一篇就够了
查看>>