版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/SSL_Yyx/article/details/84889420
线段树 离散化练习题一
Description
桌子上零散地放着若干个盒子,桌子的后方是一堵墙。如右图所示。现在从桌子的前方射来一束平行光, 把盒子的影子投射到了墙上。问影子的总宽度是多少?
Sample Input
20 //桌面总宽度
4 //盒子数量
1 5
3 8
7 10
13 19
Sample Output
15
Hint
数据范围
1<=n<=100000,1<=m<=100000,保证坐标范围为[1,n].
思路
先把所有端点坐标从小到大排序,将坐标值与其序号一一对应。这样便可以将原先的坐标值转化为序号后,对其应用前一种算法,再将最后结果转化回来得解。
该方法对于线段数相对较少的情况有效,时间复杂度(n^2)。
程序
#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
using namespace std;
long long m,n,ans,b[100001][2],a[200001];
int main(){
cin>>m>>n;
for (int i=1;i<=n;i++){
cin>>b[i][1]>>b[i][2];
a[2*i-1]=b[i][1];
a[2*i]=b[i][2];
}
sort(a+1,a+2*n+1);
for(int i=2;i<=2*n;i++)
for(int j=1;j<=n;j++)
if (a[i]>b[j][1]&&a[i]<=b[j][2]){
ans+=a[i]-a[i-1];
break;
}
cout<<ans<<endl;
return 0;
}