luogu#P5859. 「SWTR-3」Plane Mirrors

「SWTR-3」Plane Mirrors

题目背景

A\mathrm{A} 在学物理。

老师在讲“平面镜成像”这个物理现象。

但老师讲课太无聊,所以他就睡着了。

题目描述

A\mathrm{A} 梦见自己站在了一个平台上,在他的周围有一些平面镜,我们假定他的位置为 (0,0)(0,0)

他发现,每个平面镜都有一个初始不透明度,记做 viv_i

下文中,我们定义:

  • 一个射线的“不透明度”为:该射线穿过的所有平面镜的初始不透明度之和。

  • 一个平面镜的“视觉不透明度”为:所有(0,0)(0,0) 发出经过该平面镜的射线的不透明度最大值。

A\mathrm{A} 突然发现自己能够控制这些平面镜,于是就有了下面这道题目。

A\mathrm{A} 需要你完成以下操作:

1 x1 y1 x2 y2 v:变出一个两端分别在 (x1,y1),(x2,y2)(x_1,y_1),(x_2,y_2),初始不透明度为 vv 的平面镜。

2 d:摧毁第 dd 个变出来的平面镜,保证未被摧毁。

3 x y:设 A=(0,0),B=(x,y)\mathrm{A=(0,0),B=(x,y)},询问射线 AB\mathrm{AB} 的不透明度。

4 d:询问第 dd 个平面镜的视觉不透明度,如已被摧毁则输出 oops!

输入格式

第一行,一个整数 nn,表示操作次数。

接下来 nn 行,第 ii 行先是一个整数 optopt,然后:

  • 如果 opt=1opt=1,五个整数 x1,y1,x2,y2,vx_1,y_1,x_2,y_2,v

  • 如果 opt=3opt=3,两个整数 x,yx,y

  • 否则一个整数 dd

输出格式

对于每一个 3,43,4 询问,输出一行答案。

11
1 -1 2 2 -1 7
1 2 2 -1 0 10
1 2 1 1 -1 17
3 5 4
3 -99999 0
3 -3 6
3 1 -1
4 2
2 1
4 2
4 1

7
10
17
17
17
10
oops!

提示


样例解释

如图,蓝色代表射线,红色代表平面镜。

对于第 11 次询问:可以看出射线只穿过了平面镜 11,答案为 77

对于第 22 次询问:可以看出射线只穿过了平面镜 22,答案为 1010

对于第 33 次询问:可以看出射线穿过了平面镜 1,21,2,答案为 7+10=177+10=17

对于第 44 次询问,可以看出射线穿过了平面镜 33,答案为 1717

对于第 55 次询问,可以看出穿过平面镜 22 的不透明度最大的射线为 (0,0)(2,2)(0,0)(2,2)(射线不唯一),穿过了平面镜 1,21,2,答案为 7+10=177+10=17

对于第 66 次询问,可以看出穿过平面镜 22 的不透明度最大的射线为 (0,0)(2,2)(0,0)(2,2)(射线不唯一),穿过了平面镜 22,答案为 1010

对于第 77 次询问,因为平面镜 11 已被摧毁,所以输出 oops!


数据范围与约定

测试点编号 nn\leq 特殊性质
141-4 10001000 x,yx,y 绝对值小于 10310^3没有 44 询问
585-8 2×1052\times 10^5 所有 yy 相等
9129-12 x0x\ge 0
132013-20

对于 100%100\% 的数据,有 1n2×1051\leq n\leq 2\times 10^51v1031\leq v\leq 10^30x,y1050\leq |x|,|y|\leq 10^5

保证平面镜的总数不会超过 10510^5

保证所有平面镜不会穿过 (0,0)(0,0),但不保证平面镜会退化成一个点。

保证所有 33 询问 (x,y)(0,0)(x,y)\neq(0,0)


对于所有测试点,时间限制 2s2\mathrm{s},空间限制 128MB128\mathrm{MB}