本文主要是介绍线段树(li san hua)练习题一,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
线段树 离散化练习题一
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>
这篇关于线段树(li san hua)练习题一的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!