社区讨论

不理解这么出题有什么意义

P2612[ZJOI2012] 波浪参与者 25已保存回复 29

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
29 条
当前快照
1 份
快照标识符
@m0n90qlr
此快照首次捕获于
2024/09/04 10:38
去年
此快照最后确认于
2025/11/05 02:01
4 个月前
查看原帖
题意省流:假概率计数题,保留 KK 位输出,其中 K30K\leq30
且不论未定精度在输出上卡选手一下,这个 K30K\leq30 意味着 long double 跑不了了,于是题解区的大伙掏出了 __float128 或手写高精度。但是这两个东西都跑得贼慢,于是大伙不约而同地使用了:
  • K8K\leq8 则用 double / long double
  • 否则用 __float128
这不是纯纯人类迷惑行为吗?我 nn 的大小跟 KK 又没有关系,这个判断意义何在呢?
于是我拿下来每一篇题解,用极限数据 100 0 30 跑一遍,电脑配置 NOI linux 2.0, Intel® Core™ i5-9500T CPU @ 2.20GHz × 6 ,编译选项 -std=c++14 -Wall -O2,每一篇题解都要 15 至 20 秒甚至更多才能跑完。然后我又把最优解拿下来测了测,他也要跑 9s+。
在好奇心的驱使下,我去 assert 了一下数据,结果 K=30K=30 的点里 nn 最大只有 5050
[汗][汗][汗][汗]
明明这题只需要固定精度或者加个取模就可以避免这么多问题,但是出题人他偏不,就喜欢在这种地方加『难度』。这还是省选题,不知道他想要区分谁出来。场上选手发现自己极限数据过不去疯狂卡常然后你告诉他嘿嘿没有极限数据你需要按数据分治我相信是个人都会攥紧拳头痛骂出题人不是人。
于是这个题怎么办呢?你直接把 hack 加到 0 分 subtask 那么恭喜所有人都 unaccepted100 了。我的建议是把主题库的这个题题面改一下就令 K8K\equiv8 或者 K8K\leq 8 然后再在 U 字题目里把这个题原汁原味地端上来谁爱写谁写。

回复

29 条回复,欢迎继续交流。

正在加载回复...