luogu#P4097. 【模板】李超线段树 / [HEOI2013] Segment
【模板】李超线段树 / [HEOI2013] Segment
题目描述
要求在平面直角坐标系下维护两个操作:
- 在平面上加入一条线段。记第 条被插入的线段的标号为 。
- 给定一个数 ,询问与直线 相交的线段中,交点纵坐标最大的线段的编号。
输入格式
本题输入强制在线。
输入的第一行是一个整数 ,代表操作的个数。
接下来 行,每行若干个用空格隔开的整数,第 行的第一个整数为 ,代表第 次操作的类型。
若 ,则后跟一个整数 ,代表本次操作为查询所所有与直线 相交的线段中,交点纵坐标最大的线段编号。
若 ,则后跟四个整数 ,记 ,。本次操作为插入一条两端点分别为 , 的线段。
其中 为上次询问的答案,初始时,。
输出格式
对于每次查询,输出一行一个整数,代表交点纵坐标最大的线段的编号。若不存在任何一条线段与查询直线有交,则输出 ;若有多条线段与查询直线的交点纵坐标都是最大的,则输出编号最小的线段,同时 也应更新为编号最小的一条线段。
6
1 8 5 10 8
1 6 7 2 6
0 2
0 9
1 4 7 6 7
0 5
2
0
3
提示
样例 解释
对于第一次操作,解密后为 1 8 5 10 8
。
对于第二次操作,解密后为 1 6 7 2 6
。
对于第三次操作,解密后为 0 2
,此时 被更新为 。
对于第四次操作,解密后为 0 11
,此时 被更新为 。
对于第五次操作,解密后为 1 4 7 6 7
。
对于第六次操作,解密后为 0 5
。
数据范围与约定
对于 的数据,保证 。
对于 的数据,保证 ,,。
提示
不保证 。对于一条 的线段,认为其与 的交点为其两端点中纵坐标较大的端点。