博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
离散化问题
阅读量:5322 次
发布时间:2019-06-14

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

描述

一天A和B所在的学校举办社团文化节,各大社团都在宣传栏上贴起了海报,但是贴来贴去,有些海报就会被其他社团的海报所遮挡住。看到这个场景,A便产生了这样的一个疑问——最后到底能有几张海报还能被看见呢?于是B肩负起了解决这个问题的责任:因为宣传栏和海报的高度都是一样的,所以宣传栏可以被视作长度为L的一段区间,且有N张海报按照顺序依次贴 在了宣传栏上,其中第i张海报贴住的范围可以用一段区间[a_i, b_i]表示,其中a_i, b_i均为属于[0, L]的整数,而一张海报能被看到当且仅当存在长度大于0的一部分没有被后来贴的海报所遮挡住。那么问题就来了:究竟有几张海报能被看到呢?

输入

每个测试点(输入文件)有且仅有一组测试数据。每组测试数据的第1行为两个整数N和L,分别表示总共贴上的海报数量和宣传栏的宽度。每组测试数据的第2-N+1行,按照贴上去的先后顺序,每行描述一张海报,其中第i+1行为两个整数a_i, b_i,表示第i张海报所贴的区间为[a_i, b_i]。对于100%的数据,满足N<=10^5,L<=10^9,0<=a_i<b_i<=L。

输出

对于每组测试数据,输出一个整数Ans,表示总共有多少张海报能被看到。

样例输入

5 10

4 10

0 2

1 6

5 9

3 4

样例输出

5

1 #include  2 #include 
3 #include
4 #include
5 #include
6 #include
7 #include
8 #include
9 using namespace std;10 const int maxn = 100000 + 10;11 int N, L, M, a[maxn], b[maxn], f[maxn * 2];12 map
hash;13 14 int find(int x)15 {16 return f[x] == x ? x : f[x] = find(f[x]);17 }18 19 int main()20 {21 scanf("%d%d", &N, &L);22 hash[0] = 1;23 hash[L] = 1;24 for (int i = 0; i < N; i ++) {25 scanf("%d%d", &a[i], &b[i]);26 hash[a[i]] = 1;27 hash[b[i]] = 1;28 }29 for (map
::iterator iter = hash.begin(); iter != hash.end(); it ++) {30 M ++;31 f[M] = M;32 iter->second = M;33 }34 int Ans = 0;35 for (int i = N - 1; i >= 0; i --) {36 int x = hash[a[i]];37 int y = hash[b[i]] - 1;38 y = find(y);39 if (y >= x) {40 Ans ++;41 while (y >= x) {42 f[y] = y - 1;43 y = find(y);44 }45 }46 }47 printf("%d\n", Ans);48 return 0;49 }

 

posted on
2014-11-30 22:21 阅读(
...) 评论(
...)

转载于:https://www.cnblogs.com/geekpaul/p/4133850.html

你可能感兴趣的文章
C语言学习记录_2019.02.06
查看>>
界面交互之支付宝生活圈pk微信朋友圈
查看>>
字符串比较
查看>>
epoll 技术(转)
查看>>
<转>Shell脚本相关
查看>>
使用FreeMarker加载远程主机上模板文件,比如FTP,Hadoop等(转载)
查看>>
Java的位运算符具体解释实例——与(&amp;)、非(~)、或(|)、异或(^)
查看>>
java 注解 学习
查看>>
[leetcode]403. Frog Jump青蛙过河
查看>>
英语音节知识
查看>>
IEEE 802.15.4协议学习之MAC层
查看>>
AngularJS学习篇(十三)
查看>>
Tableau 学习资料
查看>>
中断和异常
查看>>
lucene 全文检索工具的介绍
查看>>
C# MD5-16位加密实例,32位加密实例
查看>>
无线点餐系统初步构思
查看>>
AJAX
查看>>
前端之CSS
查看>>
List注意点【修改】
查看>>