luogu#P7603. [THUPC2021] 鬼街
[THUPC2021] 鬼街
题目描述
那条街有“鬼街”之称,十年前是 A 市最繁华的地段之一,然而如今这里已无活人居住。
街边七零八落地排着 座房子,每栋房子都有一个 到 之间的独一无二的编号,用仿佛来自地狱的黑漆涂在破瓦残砖上,在黄尘中隐隐若现。
传说,这条街上的鬼是与别处的鬼是不同的,它们喜欢研究数论,会根据数字的性质来选择自己的生活,所以它们才为每一栋房子都画上了编号。
新上任的 A 市市长并不相信魑魅魍魉的传言,为了探清真相,他决定为这条街装上灵异事件监控器。
下面有 个事件依次发生。
- 灵异事件:在以 的所有质因子为编号的房子里,都发生了 次闹鬼。由于神秘的原因,次数 可能为 。
- 监控事件:有一个监控器被安装,其监控以 的所有质因子为编号的房子,当累计的闹鬼总次数达到阈值 时,该监控器会触发报警(若 ,则不论被监控的房子是哪几栋,下一次灵异事件都会立即触发该监控器的报警)。不同房子发生的灵异事件次数会被分开统计,不同的监控器互不影响。所有的监控器被从 开始依次编号。
请将所有的报警反馈给市长,即每个灵异事件之后,有哪些监控器被触发。
输入格式
输入的第一行依次包含两个正整数 和 ,保证 。
接下来 行,每行依次包含三个非负整数 , 和 。其中 ,若 为 ,表示这是一个灵异事件;若 为 ,表示这是一个监控事件。保证 ,。由于神秘的原因,你无法直接得到真实的 ,假设 为上一个灵异事件触发的监控器的数量(如果尚未有灵异事件发生,则 为 ),真实的 为 。 和 在每个事件中的具体含义如上所述。
输出格式
对于每一个灵异事件,依次输出一行。行首是一个非负整数 ,表示这个灵异事件触发的报警数量,之后是 个从小到大排列的整数,表示触发的监控器的编号。
20 9
1 10 2
0 5 0
0 6 1
0 7 1
0 15 1
1 12 3
0 8 0
1 5 0
0 8 2
0
0
0
1 1
0
2 2 3
提示
【样例解释】
在本样例中,依次发生了以下事件:
- 安装了 号监控器,监控编号为 和 的房子,报警阈值为 。
- 发生了一次灵异事件, 号房子似乎有闹鬼,但次数为 ,没有报警被触发。
- 发生了一次灵异事件, 号和 号房子发生了 次闹鬼。 号监控器上的累计次数达到了 ,但尚未触发报警。
- 发生了一次灵异事件, 号房子发生了 次闹鬼,没有报警被触发。
- 发生了一次灵异事件, 号和 号房子发生了 次闹鬼。 号监控器的累计次数达到阈值 ,触发报警。
- 安装了 号监控器,监控编号为 和 的房子,报警阈值为 。
- 发生了一次灵异事件, 号房子发生了 次闹鬼。 号监控器的累计次数达到了 ,但尚未触发报警。
- 安装了 号监控器,不过其阈值为 ,所以下一次灵异事件必会触发其报警。
- 发生了一次灵异事件, 号房子发生了 次闹鬼。 号监控器的累计次数达到了 ,超过了其报警阈值 ,所以被触发了报警。同时 号监控器的报警也被触发。
【题目来源】
来自 2021 清华大学学生程序设计竞赛暨高校邀请赛(THUPC2021)。
题解等资源可在 https://github.com/yylidiw/thupc_0/tree/master 查看。