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
0,1,2,……,L,都种有一棵树。
由于马路上有一些区域要用来建地铁。这些区域用它们在数轴上的起始点和终止点表示。已知任一区域的起始点和终止点的坐标都是整数,区域之间可能有重合的部分。现在要把这些区域中的树(包括区域端点处的两棵树)移走。你的任务是计算将这些树都移走后,马路上还有多少棵树。
Input
输入的第一行有两个整数
L
(
1
<
=
L
<
=
10000
)
L(1 <= L <= 10000)
L(1<=L<=10000)和
M
(
1
<
=
M
<
=
100
)
M(1 <= M <= 100)
M(1<=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 我竟然退化到来打“校门外的树”这种水题了,我太菜了。。
当然,这次用了一个新学的算法【离散化】。
代码
#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);
}