校门外的树 SSL 1044【离散化】

Time Limit:1000MS Memory Limit:65536K
Total Submit:232 Accepted:141


Description
  某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是 1 1 1米。我们可以把马路看成一个数轴,马路的一端在数轴 0 0 0的位置,另一端在 L L L的位置;数轴上的每个整数点,即 0 , 1 , 2 , … … , L 0,1,2,……,L 012L,都种有一棵树。
  由于马路上有一些区域要用来建地铁。这些区域用它们在数轴上的起始点和终止点表示。已知任一区域的起始点和终止点的坐标都是整数,区域之间可能有重合的部分。现在要把这些区域中的树(包括区域端点处的两棵树)移走。你的任务是计算将这些树都移走后,马路上还有多少棵树。


Input
  输入的第一行有两个整数 L ( 1 < = L < = 10000 ) L(1 <= L <= 10000) L1<=L<=10000 M ( 1 < = M < = 100 ) M(1 <= M <= 100) M1<=M<=100 L L L代表马路的长度, M M M代表区域的数目, L L L M M M之间用一个空格隔开。接下来的 M M M行每行包含两个不同的整数,用一个空格隔开,表示一个区域的起始点和终止点的坐标。

Output
  输出包括一行,这一行只包含一个整数,表示马路上剩余的树的数目。


Sample Input

500 3
150 300
100 200
470 471

Sample Output
298
__
Hint
对于 20 20 20%的数据,区域之间没有重合的部分;
对于其它的数据,区域之间有重合的情况。


解题思路
Q W Q QWQ QWQ 我竟然退化到来打“校门外的树”这种水题了,我太菜了。。
当然,这次用了一个新学的算法【离散化】。
校门外的树 SSL 1044【离散化】_第1张图片

校门外的树 SSL 1044【离散化】_第2张图片


代码

#include<algorithm>
#include<iostream>
#include<cstdio>
#include<cmath>
using namespace std;
int n,l,ans,x[110],y[110],a[300];
int main(){
	scanf("%d%d",&l,&n);
	for(int i=1;i<=n;i++)
	{
		scanf("%d%d",&x[i],&y[i]);
		a[2*i-1]=x[i];
		a[2*i]=y[i];
	}
	sort(a+1,a+2*n+1);
	for(int i=1;i<=n*2;i++)
	{
		bool k=0;
		for(int j=1;j<=n;j++)
		{
			if(a[i]>x[j]&&a[i]<=y[j])
			{ 
				ans+=a[i]-a[i-1];
				k=1;
				break; 
			} 
		} 
		if(!k)ans++;
	} //此方法的时间复杂度决定于线段数的平方。 对于线段数较多的情况此方法效率太低。
	printf("%d",l-ans+1);
}

你可能感兴趣的:(离散化)