#HK4329. 「CEOI2013」电车
「CEOI2013」电车
题目描述
电车上的座位按网格排列,网格由 行(编号为 到 )和两列(编号为 和 )组成。两个座位之间的距离,一个在第 行第 列,另一个在第 行第 列,是相应网格方格中心之间的欧几里德距离 。
大多数乘客在使用公共交通时喜欢独处,他们总是尽量选择一个离其他乘客尽可能远的座位。更准确地说,当乘客进入电车时,他或她会选择一个空座位,该座位与最近的已占用座位的距离尽可能远。如果有不止一个这样的座位,他们总是会选择行号较小的座位,如果仍然有多个这样的座位,他们会选择列号较小的座位。乘客选择座位后,他或她将一直坐在那里,直到离开电车。如果电车是空的,下一个进入的乘客总是会选择第 行第 列的座位。
编写一个程序,给定一系列事件,每个事件都是乘客进入或离开电车,确定每个乘客坐在哪里。电车最初是空的。
输入中有 个事件,从 到 按发生的顺序编号。有两种类型的事件:E 类型的事件对应乘客进入电车,L 类型的事件对应乘客离开电车。对于 L 类型的事件,还会给出整数 ,表示在事件 进入的乘客在该事件中离开。
输入格式
输入的第一行包含两个整数 和 ,表示电车中的行数和事件数。接下来的 行包含事件的描述,其中第 行包含事件 的描述:要么是字符 E,要么是字符 L 后跟一个空格和整数 。每个 都是合法的,即事件 是 E 类型,并且不会有乘客试图离开两次。
输入数据保证每当乘客试图进入电车时,电车中总是至少有一个空座位。
输出格式
输出的行数应该等于输入中 E 类型事件的数量。对于每个 E 类型的事件,按其发生的顺序,在一行中输出乘客选择的座位的行号和列号,用一个空格分隔。
3 7
E
E
E
L 2
E
L 1
E
1 1
3 2
1 2
3 1
1 1
13 9
E
E
E
E
E
E
E
E
E
1 1
13 2
7 1
4 2
10 1
2 2
3 1
5 1
6 2
10 9
E
E
E
E
L 3
E
E
L 6
E
1 1
10 2
5 2
7 1
4 2
2 2
4 1
数据范围与提示
- 对于 的测试数据,。
- 对于 的测试数据,。
- 对于 的测试数据,。
- 对于 的测试数据,$1 \leq N \leq 1.5\cdot 10^5, 1 \leq M \leq 3\cdot 10^4$。