bulijiojiodibuliduo的博客

博客

Tags
None

WPC 2024 Recap

2024-10-30 22:49:35 By bulijiojiodibuliduo

谁都没有想到,被我们寄予厚望的杜宝,倒在了 16 强。

比赛前

再说。

Round 1: Welcome

开场创人,释放一下出题人的恶意。

比赛前一天晚上冥想的时候,发现前四个题就是中国平谷。然后感觉 Country Road 应该有个国字形的区域,然后想了一下王字形的区域好像是无解的。

比赛的时候,Midloop 做了做,感觉不太对,不像是那种 35 分的题目,做了一会儿发现不会做就跳去做 cr 了,乱画了一通还好做对了。然后看 bloop,看了一眼,没感受到那股劲儿。然后就去做 canal view 了,做了一会儿,好像上面做爆了。这个时候想了想感觉再跳题就全错了,然后擦了上面的调了一下,就做对了。mos 签到题,感谢嘉和逆天的馈赠。三星 sb,看着就不像是个 45 分的题目。感觉看前面的题,做的不够快,还不像是自己的问题。这个三星星战,无论如何,都不太像一个 45 分题。 然后逻辑了一半,下面试了一下,还好没做错。这个时候回去,补了一下第一个 midloop,感觉每个角落,都不太好做。最后几分钟,为了保住国籍,做了一下 25 分的 letter weights,因为只有 9 个字母,所以简单列一下方程就比较好试。

然后这轮做的好像,不特别烂。赛后补了一下 bloop 和 scrabble,感觉都是好题。

Favorite puzzle : Scrabble, Balance Loop。

剧透: Scrabble 感觉就是做起来还蛮爽的,中间做的时候感觉比较有道理,以及最后 pack 几个单词的时候也比较有趣味。 Balance Loop 感觉上面一排起步的结构很趣味,后面难度中规中矩。

Round 2: Classic Dozen

诶,沟槽的协会 12 题。没想到,在 WPC,还要做这个。

一开始做 tapa,一分钟就做完了,感觉无敌了。然后忘了,感觉做了点,低分题, hashi, tents, akari, masyu。

slitherlink 好像做爆了,然后疯狂调,结果全错了。擦了重做,还是全错。好像之前选拔赛,也是 slitherlink 做爆的,感觉这个题型,可能不太能乱做啊?nurikabe 本来也是一分钟题,但是右上角 3 画错了,中间的 4 也画的不太对,差一格,然后没有悟出来该怎么调,就擦掉重来了。

然后做了一下蛇,感觉也几乎是个一分钟题。最后 hitori,slither,shikaku,三个题都做了一半爆了。成功的,又没有获得 200 分。

赛后好像听说,几乎没有人,做出了 15 分的 shikaku。后面补了一下 kakuro 和 四风,感觉其实,都不那么难?

Favorite puzzle : Slitherlink, Hitori。

剧透: 在清算嘉和逆天 slither 是不是用 pzprrt 出的时候,意外发现,这个题下面有个奇偶性的逻辑还蛮趣味的。然后 Hitori 虽然是一个视力题,但是你要观察到第一排和副对角线相同就比较好做。

Round 3: Miscellaneous

最像人的一轮。感觉题目都比较像会做的。

首先上来做了 yajilin,乱做了一下,不出意外的全对了。感觉这轮的题,比较简单,所以没啥印象。反正就大部分的题,几乎就随便做一下就对了,感觉这才是正常比赛,有的那种劲儿。

battleship 好像盲猜了两个 3 的船的位置,一下子做对了。pento 好像,稍微调了一下,因为一开始把对的调错了。

Pyramid Climbers 因为在出 PGP Practice Set 的时候摆过,赛前好像就猜到了可能的逻辑,(剧透: 比如说可以通过看一些格子隔几层会到什么地方卡住,或者可能会有很多个相同的字母一起下去,然后路径之间会互相卡住之类的。) 然后在赛题里很快就看到了起步,后面基本就是视力题了,也做的不太慢。

最后几分钟扫雷的时候,可能因为时间不太够,导致中间做错了,然后最后也没调对。边上的哥们做完了并且获得了 bonus,本来以为这轮只是做的不错,结果好像是第二。

Favorite Puzzle: Pyramid Climbers

别的题目可能有不错的,但感觉比赛时候做的,又很多不太逻辑,所以没留下太多的印象。

Round 4: Puzzle Chain

本来以为走上了正轨,没想到上一轮是最后一轮像人的。

这一轮题目,看着就有点魔怔。一堆低分题,加上两个大 number placement。onetox 感觉在 GP 里做的时候,就属于比较慢的,比赛前制定的策略是扔了 1到x,去做 japanese sum。jsum 因为 ib 里面强调了可能是 0,所以以为是带 0 的,结果真题是只是一个比较大的。

感觉其他题做起来确实还挺顺的,arrow maze 因为从来没会过,所以先放了。x和好像靠着一手瞎做迅速解决了。all or nothing 感觉比想象中的难一些。主要平时做 all or nothing 一般都直接乱做,没太思考过这个题型的逻辑,但事实上有一些奇偶以及边界相关的逻辑,类似简化版的doubleback。double or nothing 好像是一个非常简单的题,一开始还担心记号的问题,试完第一个 + 之后感觉整个题几乎就做完了。chocobanana 因为看着只有25分,根据之前 shikaku 的经验,很有可能是个不太能做的题,就扔了。

然后去做 jsum,jsum 平时在做题中,特别是小盘,感觉经常感受那股劲,比如说感受一个数如果和横竖线索都匹配得很好,那么它就很大概率是对的。但这个在大盘里风险很大。不过感觉还是做了一会儿之后就找到了入手点。但是做着做着发现上半盘爆了,然后开始爆调一通。然后就在玉玉症中结束了比赛。

最后发现 jsum 下面已经已经错了,以及上面部分离正解可能差挺远。而且感觉做的过程中没有特别逻辑,所以后面就没救了。然后赛后听 CHN 的队友们说 1到x 是简单题,但自己做了一下,好像也没那么简单。仔细想了想好像和我说简单的人分别是 WSC 第一第二第三第四。

Favorite puzzle: Nuribou, Choco Banana

剧透: 感觉 Nuribou 是这一轮为数不多的比赛时候做的,并且感觉有点趣味的题。Choco Banana 虽然比赛的时候没有做,但有不错的入手点,以及后面在逻辑和 intuition 中有不错的平衡。Japanese Sum 和 One To X 虽然都比较不错,但你们数独没有自己的比赛吗?

Round 5: Elemental Cycles

吃完午饭,很困。噩梦,开始了。感觉,这一轮,非常的德。

这一轮也是一堆低分题,加俩大的德国题和一个 statuepark。

感觉,我比较会做的题型,都是一堆低分题,很快就做完了。anglers,感觉有点趣味,但感觉很多 anglers,都有着类似的趣味。tents,感觉有点趣味,但主要还是比较漫长的瞪眼。araf,诶。nurimisaki,诶。感觉这两个题,有点,敷衍。

u-bahn,赛前就觉得出题组看起来没人会 u-bahn 的,然后果然是个简单题。然后在 laser 和 sp 之间,选择了 laser,因为感觉验题组应该有 sp 大手子,sp 标了 75 可能真的很难。但是验题组应该没有德国人。做了很久,虽然整体感觉是乱做,但还是差不多感受到了那股劲儿,做了出来。

最后做了个 20 分的 herugolf,感觉,分数标的还是没啥道理,调了很久才做对。

做完之后自我感觉还不错。

结果 laser 错了 2 bits,sp 听说不太难,然后人均三个大题能做俩,结果我只做了一个,就由还不错变成倒闭了。CJK 做完了这一轮,保住了国籍。

yosenabe 好像是一个蛮简单的题,但是根据之前轮次的经验,怕出题人在 20 分题里面喂屎,比赛的时候就没做。这个题确实比高尔夫简单不少。

然后做 sp,感觉不太懂。本来想喷的,但重新悟了一下,感觉这个题还是它的道理在。

Favorite puzzle: 没了(可以到时候重新悟一下 laser)

感觉这轮,好像没啥喜欢的题。感觉就是,会做的题,都是低分题。难题,有点道理,但缺乏快乐。

Round 6: Solar Terms

105分钟轮,大大大爆炸。

开场做了lits, worm,aquapelago。感觉和数独大师在一起久了,觉得自己又行了,直奔 number placement 区。感觉 kakuro, skyscraper 和 magic summer 都比较简单。然后 kakuro(hex) 因为瞎眼,所以卡了比较久。topheavy 不会做,因为 7x7 感觉比较小,就开始爆试。然后赛博鬼打墙了,试了很久都没有试出来。赛后问了老师们 topheavy 好像都是试的,然后 playoff 的时候逮捕了戴老师教我做,结果好像也不会逻辑。

然后去做了 sashigane,感觉是一个,很难的题,可能带着一点 theory?做的时候没有感受到入手点在哪里,然后花费了很多时间在随机爆试上面。heavy dots 和 5c 都是简单题。后面回路也做了点小题。

最后时间一直在调 lits(splitter) 和 top heavy。然后出来算了一下分,发现大分题爆干净了,小分题小爆,只有不到600。然后出来大家好像都有七八百,就有点爆。

感觉这一轮就在 sashigane 和 kakuro(hex) 上花费了太多时间。然后 lits(splitter) 和 topheavy 又做不对。

赛后做了一下 dominoes 和 大的 icebarn。感觉 dominoes,非常简单,100分题感觉能做至少 15ppm。大的 icebarn 感觉没有小的 icebarn 趣味,并且卡点都是几个 lookahead,中间的逻辑也比较单一,但想想这样的结构好像解确实只能长这样。有点瞎但终归是好做的,可能对这个题型不那么自信所以没有去开。比赛的时候,感觉选题选的不那么对。

Favorite puzzle: Fillomino(Matching Splitter), LITS(Splitter)

fillomino(splitter) 感觉整场最佳 WPC 最佳单题,伟大无需多言。但因为没有摆过练习题,对这个题型缺乏基本理解,感受不到边界限制很强的那股劲儿,所以感觉现场几乎不可能做出来。lits(splitter) 比赛的时候陷入了调整的泥潭,但实际上有个比较清晰的逻辑路径。

Round 7: Duality

不太知道,怎么评价的一轮。

感觉基本做下来比较顺。Go 感觉整体比较逻辑,没有邱在 ws+pc 里出的那么意识(虽然比赛的时候还不知道是谁出的)。然后一开始左边的 15 只凑到 14 口气,还好冷静了一下,调对了。中间这些 loop 完全没有练过,都是凭底力做的。本来以为能轻松拿下的,结果 kuroshiro 做爆了,然后开始在中间无限重启都没有用。赛后发现右下角有两个点之间拐了 1919810 次没发现。感觉又是花了很多时间没有做出来的题。

75分的 kropki pair 直接扔了,赛后补题发现,好像是一个中规中矩的题。clockfaces 好像,根本没有发现要全标。感觉当时读 ib 的时候,队友都是数独大师,加上我没仔细看,所以就我不知道要全标。consecutive quad 感觉赛前对 6x6 的 1 线索进行了一些简单分类,但比赛的时候大概知道了起步,但没有做下去。赛后补题感觉比较好择,但不太知道具体怎么逻辑的。

最后赛博鬼打墙了很久 kuroshiro 就扔了,然后去 rush 了 pearl loop,然后 rush milk tea,做了一半没做完。

kuroshiro 赛后补的时候感觉还是比较奇怪,就它有很多 lookahead,而且做到一半小试了一下才做出来。感觉看不太透这个题型/题目。

Favorite puzzle: Go, Milk Tea

Go 感觉就是比较正统的好题,从题型到这个题的实操都挺好的。这个 Milk Tea 虽然很简单,但感觉是为数不多的爽题。最后时间 rush 感觉挺爽的,但做的还算逻辑。以及赛后补题的时候感觉直接调起来就更爽一点。

Day1 的晚上

晚上 R5 的卷子批出来了。发现 Laser 爆了 -80,有点玉玉症。然后后面比较晚 R6R7 也出来了,R6 就低的根本不是人。R7 其实因为 kuroshiro 爆了,其实也不太高。然后 not alone 错了两个 bits,表面根本没看到全标也错了,导致这一轮分数 -50 了。

出完分之后发现成为 11 强了。

然后晚上其实很困,重新做了点之前做过的练习题,感觉状态也不太好。很多题做的比初见还慢。然后入睡困难,可能是因为白天 monster 和茶摄入过多了,以及之前的作息本来就是 5am 睡觉的,只是前一天运气比较好,睡眠没有全错,这天就彻底全错了。然后狂爆摄入了三片褪黑素还是没有效果(可能是 30mg?)感觉折腾到四五点钟到正常睡觉时间才入睡。

不太清楚对 Day2 到底有多大的影响。我感觉 Day2 失败主要还是因为犯了太多错误。但很难说睡眠不足对机能的影响。

Round 8: Eleven Years Later

可能刚起床,困劲没上来。听说是 WPC 2013 狗都不做的题型精选。

这轮又是一个大 thermo,剩下一堆中分题和小分题。策略就是做一下 thermo,感觉没有 thermo 的话这轮可能有倒闭了。

上来做 thermo,上来对着长温度计意识流了一段,然后做到一半开始小试,以为做对了。结果有两行两列的线索没对上,实际上离正解差的可能也比较远,感觉不是简单调能调对的。但感觉我的试数的标记其实没有特别干净,感觉擦起来也会比较费劲。而且铅笔在灰格上涂本来就比较瞎。感觉这个题从二择试错的那一刻开始,就已经爆了。可能就是如果发现错了,就赛中爆。没有发现错,就赛后爆。

后面做了一堆小分题和中分题。做灯塔的时候好像没看到起步(猜了个错的起步),就没做出来。wall 好像不知道数错了还是逻辑错了,一开始做了个局部多解出来,不过好在擦了一些之后问题没那么大。

感觉 vista 还挺趣味,虽然(剧透:连通性的逻辑在 bakpao 的 practice puzzle 里面体现的比较多。 )。corridors 也还行(剧透:一堆区域往右边空白地方伸挺趣味的。 )spokes 不是很规则的盘面,比 2013 年的难的那个 spokes 简单不少,整体也很能逻辑。

tria 4,烂题型,别出了。triangle snake,感觉这个题型烂的有点好笑了,不太理解为啥会选这个。diagonal dissection 感觉没有瞪眼水平,不好评价。

赛后补了一下 hexagon arrangement,没看上去那么烂。hamle 感觉从题目的视觉和逻辑都挺好的,但是这个题型本身有点烂,而且不给空盘差评。

Favorite puzzle: Skyscrapers (Digital Sum)

感觉一个萌萌的题目,有一些 aha moment 在,做起来也比较轻松愉快。

赛后重新做了一下 thermo,感觉不知道是没有感受到它的逻辑还是本身就是个玉玉症题目。感觉(剧透: 整个题没有明确的逻辑点,就一堆通过平行的温度计之间的交互,然后 lookahead。然后体感就是纯逻辑瞎眼,在纸上试又有点玉玉症。)somehow 完美阐释了,这个题型,为啥没人出了。

Round 9: Variants

感觉决定不做拉丁方那一刻起,这轮就已经走远了。

这一轮又是两个高分的题,分别是 doppelblock(anti-knight) 和 statuepark(hitori)。赛前因为 22WPC ak fuzuli 和 24hpc 里 ak tomtom 的经验,以为 doppelblock 可能是一个 7x7 的那种没啥线索,然后需要精妙无马区块之类的才能做的题。

然后比赛就从 slither(touching) 开始做,感觉是个,白痴题。然后 pentopia(diagonal),好像基本上也没啥难点,就是步骤比较长,需要数格子。然后 maxiloop 和 nurimisaki,好像都没难度。然后去做高分 sp,感觉这个 sp 比较符合对这个题型的预期,也比 ib 的题逻辑的多。前面做的比较顺,但是做到最后4个收尾的时候,好像估价函数出了巨大偏差。(剧透: 以为 10 上面的得是个 X 或者往上伸成为 N。)然后对着最后四块玉玉症了一会儿,以为自己前面做错了。然后重新来了一遍发现也都是逻辑的。期间顺便做了一下后面的星战和楼。感觉这个 35 分星战比 R1 的 45分星战,简单了不止一倍。楼看卷子上好像是出了两行之后剩下的都是试的。但感觉 6x6 但是 45 分的楼,直接试可能全对。最后做了一会儿才发现(剧透: 10 得是个横着的 N。 剩下的时间看了看 hashi,发现找到了起步,但是找完起步之后,忘记把画的边对称过去了,导致不知道接下来该怎么做。akari 也找到了 (剧透: 6列的鱼,但没注意到前两列只占了两行。)但感觉主要的时间还是在玉玉症这个 nurikabe。这个 nurikabe,感觉不好说,就比较像那种 20 分但给你喂毒的题,也可能是整个早上状态比较差,就没有良好的估价函数。

最后就做了个比较低的分数。主要是扔了 135分题,而且中分题失分也比较多。赛后做了一下 doppelblock,感觉并不那么难,至少可以做到 7.5ppm 以上。而且整个题也没有什么特别精妙的逻辑,主要是一开始瞎试一下黑格怎么涂的,然后就基本的无马拉丁方,纯看底力的那种。hashi 也是起步之后,就是一个比较正常的题目。shape division (splitter) 有点,不好评价。感觉这个题突出一个,整个题,没有半点逻辑,全靠感觉。这种题可能平时做着会比较快乐。但作为比赛题,感觉就很难评价。

Favorite puzzle: Statue Park (Hitori), Hashi(Projective Plane)

sp 这个题,其实感觉比较符合我对这个题型的想象,但整体执行地也比较有趣味,感觉是个很正统的好题。感觉比赛时候,最后四个块脑瘫了,但这个在平时好像也不太常发生。Hashi 感觉,起步非常的幽默,能让人感觉到它的乐趣。

这一轮感觉很像 R5,就给我感觉很多题型它有一些潜力,可以出更好的题,但呈现出来的就比较普通。感觉 slither(touching) 有很多逻辑和定式可以发掘,可以参考 menderbug 博客里的题 或者以前的德国比赛,但比赛题好像是个纯粹手速题。pentopia (diagonal) 明显 menderbug 的练习题更加精妙,这个题也只是最基本的数格子。nurikabe 感觉完全可以出一些,比较正常的题,比如在 deceptivepuzzles 和某年的 gp 里,都有一些比较正常的题,感觉比较难理解为什么会选择出这么个 packing 或者 penalty 题。mini loop 和 nurimisaki 也有类似的感觉,虽然 nurimisaki 因为题型本身的限制可能真的没救。

Round 10: Irregular

你们数独没有自己的比赛么?下次能不能用这个盘面出题。还有嘉和逆天,答应我,下次出 12 边形 cave 好么。

你妈

感觉整一轮,从盘面,到题目,到得分,都比较得痛苦。

然后开始做沟槽的 cave。很纯粹的玉玉症题目,然后右边还一直错。后面把上面稍微调了调,结果发现其实原来是对的。但不知道为啥做错了。感觉这个 cave 可能需要一点科学的 notation?或者就是个纯粹玉玉症题目。感觉 cave 要数八个方向就太瞎,这边建议就不要出了。

然后做了一下 yajikazu,感觉整体没啥太难的地方。中间可能花了大于 3 分钟去做 straight cross,以为标得这么低,可能是个弱智题。结果三分钟填出了一个数。

最后时间去做 dbchoco 了,当时好像左上的 4 摆错了位置,导致中间一直无解,调了很久。但现在看见卷子好像没看到能摆下 4 的另一个位置?所以合理怀疑可能是对了个不全等的。因为浪费了很多时间导致最后没有做完这个 dbchoco。其实就只剩下中下不到 1/4 而已。

然后感觉本来 330 已经不太是人了。结果 cave 和 koburin 都错了。cave 错了 3 bits, koburin 错了 2 bits,看错了一个相邻关系。然后喜提 215 分。

比完就感觉这个 cave 太烂,很有嘉和逆天的味道,直接开喷。虽然这个题型就基本上没救了,但感觉嘉和逆天就能把题目出的味道很冲,让人留下心理阴影(包括但不限于 WS+PC 2021 的对角灯塔,大盘cave,你妈,怎么21年就干了),建议下次出十二边形的,谢谢。

然后做了一下剩下的题,感觉也很玉玉症。那个 dbchoco 感觉是剩下的为数不多是题的,没做完的可能再给一分钟差不多就画完了,也可能赛中做意识流题 debuff 比较强。补 area division 感觉做得比较逻辑,所以花了比较久。但感觉调应该会快一点。

然后 straight cross,感觉是六边形数独。感觉因为六边形限制比较强,导致看排除非常瞎,补题也做了非常久。

彭罗斯数独,好像是个,真正的困难的,3d数独。赛后听戴老师说也做了 5min+。感觉正常不规则就常年在 3ppm 徘徊,这个对我好像真有点太难了。赛后补题,都完全不会做,感觉还是有点太变态了。

arithmetic square,立方体数独。感觉补题的时候,几乎靠猜,感受那股大小关系的劲儿。不太看得透有没有逻辑做法,以及做对是不是纯靠运气。

感觉这一轮就,错太多了,可能理想发挥也就能再多个 dbchoco。抛开事实不谈,感觉这些题目也不完全干净。

这一轮虽然没有 Favorite puzzle,但是有 全场最烂题 Cave(Truncated Square)。

感觉一般的烂题,就没有烂得那么雅俗共赏。这个题就是把人骗进来杀,让人先觉得它可做,然后就是无休无止的数格子,完美平衡了瞎眼和逻辑,把所有人都搞得很红温。最后还很容易错,让做了这个题的人,不但浪费了时间,还获得不了分数。感觉最烂题,实至名归。

Round 11: Little Happiness

小四悲。

中午没睡觉,感觉快死了。比赛前,跑到厕所干呕。听了一些安神的音乐调整了一下状态。

但是这轮是 sprint 轮,所以做着做着反而状态好了一点。然后基本就顺着做,sprint 轮主打一个感觉和通灵,也没啥太多需要逻辑的。

做到差方发现不会做,然后怕出题人在 shikaku 里放毒,就整个就跳了。fillomino组的 symmarea 也没有一眼丁真出答案也跳了,subomino 感觉是唯一一个,需要逻辑的,虽然也没有一眼丁真出什么。最后快速的 rush 了填数区。

做了 177,好像勉强是人。

结果恰好错了,分数比较高的三个题,减了 14 + 8 + 7。其中 14 的 line of sight 和 8 的 myopia 几乎只错了 2 bits,railpool 有点错飞。

最后只剩下 148 了,感觉就,比较普通的成绩了。

Favorite puzzle: 没,全是手速题。

Round 12: Quadruple Happiness

大四悲。错题毁了我的翻盘梦。yyao 赔命。

这一轮又是俩大分的题,其中一个是拉丁方。然后我继续怯战。

感觉这一轮其实状态比较好,久违的那种怎么做都能对的感觉好像又回到了身上。一些回路题做的非常快,就有一股瞎做就对了的劲儿。然后差 shikaku,snakepit,和后面俩填数字的时候开了 martini 组。

这个题(剧透: 其实直接猜能更快,因为每个白色区域就和你想的一模一样。)做的整体比较顺利。然后做到最左边,也就是最后的时候,发现多解了。然后就玉玉症发作了。因为这个题是125分题,加上我扔了拉丁方,所以这个题没了整轮就又飞了。然后我就开始重新读了规则,check 了每一列的高度,标了每个区域的个数。

感觉后半程就对着这个题玉玉症和补后面的小题中来回切换。最后实在不知道咋办,就随便蒙了个解上去。整轮就只有拉丁方和蛇没有做。最后一题虽然做的不快,但感觉比想象中趣味许多。

赛后一问好像很多人都说 martini 多解了。就很难过。

不过感觉和 R9 一样,这轮感觉也是只要选择不做拉丁方,就飞了。可能正确的就是得做拉丁方,放点小题,就能轻松 500+,还得一些没看到 martini 多解或者晚做这个题的运气。

赛后补了蛇组,感觉就是,纯意识流乱画,没有半点逻辑。怀疑 subomino 根本没有用。比赛的时候稍微逻辑了左半的开头,但实际上剩下的只要乱画,1分钟就做完了,可惜太懦了。这个拉丁方做起来也比我想象中的顺很多,基本上没碰到什么卡点,整个只是大。感觉整体做起来也比较愉快。感觉如果知道作者是 yyao,比赛的时候就会去做了。这个题感觉比 yyao 在 24hpc 出的 ham sandwich 简单和愉悦不少。

Favorite puzzle: Suguru + Ripple Effect + Cojun + Makaro

虽然感觉快把我不会做的题叠满了。感觉这个题有一种,朴实无华的乐趣。也可能是数独做太少导致的。loop 和 shading 说不定有一些有趣味的,但感觉比赛时候做的,都速通了,没来得及细品。

Round 13: Secret Symmetry

好像除了我所有人都做完了。

可能上午的轮次在某个时刻出分了。然后我就知道了,上午 R8 爆了 105 分,R10 爆了 125 分,排名排到了 1919810 名了。可能玉玉症又发作了。

感觉这个 ryaj,是个简单题。然后发现 scrabble,很有感觉,就做了一下,整体比较顺利。然后做四风,可能精神比较涣散,又加上虚线框和边界太接近了。可能做着做着就把中间整个框当成对称区域了。其实一开始就猜了对的对称,但是做了一下发现,做不出来。然后感悟了一下也没感悟到更加对的对称。

后面勉强做了 tatamibari,shaka,stostone。这个 stostone 右边好像还没有一下子试对。然后就对着 aquarium,angle loop,slash pack 和 四风玉玉症。angle loop 稍微做了点,实际上编对了中间四个点的连法,但没想到(剧透: 可以中间穿过去,导致整个回路奇偶性有点不太对,看着连不太上的样子)。而且我把四风的对称性标错之后,整体好像有点,对不上了,又不知道该擦啥。然后以为slashpack 是【数据删除】,对着编了很久,在中心勉强编出了点有可能对的,但是没法往外伸。最后时刻感悟了一下 aquarium 的对称,rush 了一下,可能在还剩几秒的时候 rush 完了。

然后以为我爆的是 四风,slashpack 和 angle loop,结果卷子发下来,发现四风是对的,aquarium 爆了。而且只漏了一格,这格就是唯一一个没有涂也没有叉掉的。

听说,很多人都做完了,我又只有一半多一点,就很难过。

感觉在比赛做的时候,试这些题就没有那么自信。Matchmaker题,基本上还是你感觉什么是对的,它就是对的。感觉出题人很少能出出那种对应错了但还像个题的东西。

Favorite puzzle: Scrabble

感觉是一个,全场第二幽默(褒义)的题。

Round 14: Brain Power

真别出了。

为了保住国籍,准备去做运算区。打开卷子,发现不太对,这些题看起来,完全不像它标的分数。

勉强做了个 arithmetic square,结果还做错了。然后做 operation square,感觉这是个绝世好题,可惜比赛的时候想到了正解的方向,但是一些疏忽没想下下去,导致没有做出来。然后做 darts,感觉 darts,也比较玉玉症,虽然做了会儿大概看到了起步,但是也算了很久。赛后听说,胡老师,根本没有看到起步,直接摁调做出来了。你妈,C(13, 5),感觉,根本不是人。

看着剩下的 15个字母的 letter weights,15个字母的 elastic sums,有一种狗都不做的气息。感觉再做下去,可能要获得 60分 1ppm 离场了。

赶紧去做了 alphabet blocks 和 mastermind,这两个题虽然 30分,但感觉其实简单多了,剩下的题没太看透。然后又去做一区了。然后图同构以为应该可做。(剧透: 然后数了数度数发现几乎全是 5 度点,然后从 4 度点出发找其实非常慢。按照孙宝的说法应该注意到图里面有个大小为 4 的割,然后分成两部分做会快很多,感觉确实有点,思维定势了)剩下发现已经没啥时间了,然后去做 picture slice,结果虽然找到了区域,但是带的尺太短了,再加上没有时间了,然后只有一半真话。

赛后补了一下题,感觉运算区,operation square 可能仔细想想就能做出来。剩下的题目里面感觉除了 balance 其他都不太是题。算盘好像 WSC 冠军老师做了,但感觉这个题三个小题要都做对才有分,看着就没太想让你去做。而且看不太透,这个题是不是就纯粹瞪眼爆搜,也不太想做了。balance 其实根本没仔细读 ib,所以没有意识到(剧透: 往上的就是重量小于 0,以为只是排版问题(?)),如果意识到,这个题可能是这个区唯一一个有机会做上 10ppm 的题。letter weights 赛后做了很久发现根本不会,然后逮了验题人孙老师和做出了这个题的(不太确定)胡老师,然后编了很久精妙的逻辑步骤才教会我。听说验题的时候 12 分钟就做完了,我:???感觉和验题团队和数独大师们相比,我可能确实不太像中国人了。

别的区就感觉整体,没有计算区这么极端。单词区,letter pairs 感觉是个简单题。crisscross 感觉就是很瞎眼,但慢慢做能做出来。word search 不好说,但是找的单词个数确实比较少。elastic words 感觉入手的点确实相对趣味,但因为我没读 ib,所以根本没意识到是子图嵌入不是图同构。wordle bank,感觉不太是题。感觉就是右边的组,给了我答案,我都得花点时间验证一下为啥是对的。

然后第一区拼图,感觉不太理解为啥标这么高。就感觉这个题,其实挺简单,或者至少不玉玉症,做一会儿就做出来了,可能只是纯大?。find pairs 感觉是趣味题,最小表示法,某种意义上的算法题。old maid,感觉是,机能题,以我当时的状态肯定做不快。但至少可以划掉,所以也是花时间总能做出来的。password path,感觉就是一个,不太好做的 password path,纯逻辑能做,但是慢。而且这个题型我也没有太深刻的理解,感觉如果要做的快,应该要调。maze collector,感觉,完全不理解,感觉全靠通灵和乱画。感觉是那种你得猜哪些出口出不去,补题的时候好像猜了几个都对了才画出来。

总之这两个区都有一些相对正常,并且性价比较高的题目,虽然我也没太选到这些题。

感觉这轮除了比赛时间因为日程的关系(?)所以缩了一半,但感觉整体题目的难度也有比较大的问题。首先感觉标的分数,有点随机。当然这个和题目本身,包括 tester 少有关。然后感觉就是很多题就有一种不太想让你做的感觉,特别是 arithmetic 区。感觉第一个就是太大了,然后可能想在一个题里面塞很多东西和步骤,但这个毕竟是在一个每个题解题周期都很短的竞赛里面,感觉就得做出一些取舍。可能这些题放到 LMD 上面就是个好题,但在比赛里面出,感觉就不太合适了。

而且历年的 casual/word 轮,感觉要么是娱乐轮。要么是去年一样相对正式的轮次,从题目难度到分值上都和正式轮次差不多。感觉今年这轮就非常的玉玉症,而且在最后一轮,这下就有点有始有终了。

可能就,本意是好的,但是执行坏了。结论还是,别出了。

Favorite puzzle: Operation Square

全场最幽默的题。感觉没做出来挺可惜的。(剧透: 比赛的时候想到了 /3,但是看到 *6 以为得是偶数,就没想下去了。

Puzzle GP Playoff

So u are in top10?

yeah why not I guess I will fail only if all rounds are binary star

谁都没有想到,被我们寄予厚望的杜宝,倒在了 10 强。

Puzzle GP Playoff 的规则,是一个很狗屎的瑞士轮。

由于在 weihwa huang 的彻底疯狂下,Puzzle GP,感觉有点像个笑话。我成功在,幻方轮和🚜轮 偷鸡上大分。但是第一轮的时候服务器爆了,我发的申诉邮件再 7 个月之后才给我把分加回来,而且这个应该是在 puzzle gp playoff 排名确定之后的。然后我从第二种子变成了第八种子。蝴蝶开始煽动了它的翅膀。

playoff 分成 online 和 onsite 两部分。简单来说就是一共有十六个人进决赛,然后大家先线上做 8 个题,然后成绩线下才公布,并且按照这个成绩线下跑瑞士轮。最后每个人再现场做 O(1) 轮,确定一下最终排名。

online playoff 的题目,看起来就根本不是题。我已经有点不太理解,如果是每一轮作者自己选的话,真能选出这种东西吗?分别是 trigon, binary star, star battle, minesweeper(sudoku), ripple, skyscraper(diagonal), offspring, slither(nth seen)。大概就是 4 个 object placement,3 个 number placement 和一个正常题。而且像扫雷, ripple, offspring 都是视力题。

不过好就好在,这些题,按道理应该谁都不会,而且感觉 gp 我就是靠着这些题上的大分。而且对于每个题我都有比较充足的练习时间。然后 online playoff,感觉我整体在游龙。除了 ripple,一直都不太会,而且盘面很大,就纯慢。以及 binary star,好像 gp 比赛前和这次之前都没有自己摆过练习题,以为能靠底力直接做。然后 gp 的时候就爆了,playoff 又爆了。playoff 感觉是个比较巧妙的结构题,有没有准备会差很多。然后因为盘面比较小,一下子没想明白结构我就开始爆试,就导致做了非常久。

找了几个随机网友对了一下成绩,好像基本上都遥遥领先,胜率在 6/8,7/8 的那种,感觉剑指🏆了。

然后现场,发现我最后排到了第九,但录像放得太快了,没太看明白怎么个事。以为选手都比我想象中的牛逼。

然后就是 7 到 10 名的排位赛,我对上的是 ksun。然后我们做的题目是被 Kota 胜者组决赛 ban 掉的题,arrow maze。感觉选到这个题型我就想怯战甚至想死。简单来说,arrow maze,是我🚜轮唯一一个没有做的题。以及在做这个作者的历年题目的时候,很多都是那种 30 分,但我完全不知道该咋做的题。去年中锦赛,也有一个 30 分的 arrow maze,我赛后补题做了接近 11 分钟。

而且这个 playoff 还是有摄像头直播的,上台后我就就很想死,向台下的老师们求救。然后想了一下,感觉以我之前对这个题型,纯靠逻辑可能根本没法做。然后我就想试然后调。结果最后就全错了,好像 ksun 一下子就做完了,而且这个比赛对手做完了也没有一下子结束。然后就变成公开处刑了,我就在台上疯狂调整加绝望加玉玉症,成为了唯一一个没有做完这个题的人。

然后下台听说这个题逻辑非常简单,直接看哪些箭头有唯一出边之类的,小邱老师一分钟就做完了,更想紫砂了。

除了这个 arrow maze,剩下的题也都很搞笑。分别是 sukoro(唯一一个像是正常题的),word arithmetic(类似虫食算的小学奥数题),然后就是 easy as(diag), skyscraper, jsum + snake,三个拉丁方题。整个线上 + 线下 playoff,loop, shade 和 region 只有一个题,感觉就活在平行世界。

然后在台下做这些题,好像除了 sukoro 输给了 ksun,别的拉丁方 + 小学奥数题好像全都战胜了。小学奥数题 我和小邱老师两个人用时遥遥领先。别的拉丁方就虽然没有最快,但感觉整体在能打的范围。不过好像 easy as 和 skyscraper 没完全用逻辑,可能上去做或者猜错了也会倒闭。

最后就,倒在了第十名。

赛后 online playoff 的成绩出来了,我仔细研究了一下为啥我线上 7 轮能输 4 轮。研究了一下,每个题的排名。除了 ripple 获得了 11 名(就是纯慢,大多数人好像都有视力),binary star 做了 9 分钟,但大概也是在第 8 名的位置(看起来大多数人也不会逻辑)。剩下五个题(minesweeper 被抽到轮空了)的排名分别是 1,2,2,3,3。就是你很难想象,这个成绩都能输 4 场,我觉得无法做到更好了。

后面我来详情揭秘了一下,第一轮获得了第一名,战胜了 #9。然后根据狗屎瑞士轮规则,我是 #8,第二轮的对手是 #1,这个楼感觉虽然靠着意识流做的飞快获得了 16 人中的第二名,但好像被 EKBM 7秒的优势逮捕了。瑞士轮会 somehow 让你抽到接近的对手,但感觉我抽到的对手,都有点,不那么对。后面有一轮 offspring 我获得了第三,被这一轮做了第一的逮捕了。我输的四场对手分别是对应的这一轮用时的 rank 1, rank 2, rank 1, rank 1。

感觉这个 GP playoff 就有一种随机数种子坏了的荒谬感。

Team Round

赛前好像几乎没怎么看 team round 的 ib。好在 CHN-A 大家素质都不高,都干了等于都没干。于是大家 day2 晚上一起看。

但是 day2 晚上的时候,因为白天的 WPC 和 GP playoff,我在玉玉症发作,完全没怎么听大家安排的战术。而且感觉没有赛前那么自信了。

但是 team round 其实是做题体验最好的几轮,感受到了出题人的善意。最后一轮除外(

因为没有题目,所以下面就直接根据回忆写的,需要老师们 fact check 一下。

Team Round A: Chinese Knot

loop mashup 轮。因为我没有合适的垫板,所以做起来略玉玉症。感觉我应该是队伍里面最会做 loop 的。然后大家基本上按照座位,看卷子发下来哪个角朝谁就谁做了。然后我一开始起步是 TLL,还是比较轻松的做完了。然后我就去做边上的 maxi 了。

没太注意各个老师的进度。后面大概重新分了一下,感觉 detour 是一个可能比较需要 loop 底力的题型,然后我就被分配去做 detour 了,后面基本上是单机 detour。detour 这个题感觉本来就比较难,再加上有些地方需要边上连过来的线头,以及大盘很多情况下不敢随便乱做。

这些可能是凭记忆乱讲的,因为我没太关注大家的进度。后面好像是戴老师和小邱老师一起做了 country road。然后戴老师在 dotchi loop 做的有点全错,疯狂调整。炜凡老师在干啥来着,对不起没太注意。然后我 detour 基本上做完了,就一些全局连通性的线头可能没有画。

做完 detour 之后时间其实剩的不多了,然后发现 maxi loop 进展不大,然后就去 rush 了一下 maxi loop,但可能也没啥进展。

最后得分就是少了 6 个 quad,好像是 detour 蒙错了一个全局连通性,然后 dotchi 对了一半,maxi 只对了一个?

Team Round B: Octahedron

shade mashup 轮。一开始可能因为精神错乱,以为一共有 32 片,然后我一个人拿了 4 片(?)后面就拿了比较传统的 shade 题型,nurikabe,kurotto,canal view。小邱老师拿了 cave,戴老师拿了 minesweeper 和 pentopia,炜凡老师拿了 SLICY 和 tapa。

按照嘉和逆天的说法,我手上的三片题,好像几乎不能直接起步。大概就 nurikabe 做了一半,canal view 做了一点点,kurotto 强行找到了点起步做了一点点。就开始陷入了玉玉症。

中间好像帮炜凡老师稍微做了点 tapa,然后发现矛盾了,然后炜凡老师不知道怎么调了一下就调对了。后面老师们很快的把做的题目给拼上了,可做的片好像都在上半边,等把边界上抄过来之后,有些题就很简单。然后 nurikabe 好像就做完了。kurotto 好像抄上边界之后,被别的老师拿去做完了。(那我在干啥来着?有点失忆了)

但是炜凡老师的 SLICY 左下角做的好像不太对。导致抄过来 canal view 有点,做不出来。然后我做着做着,发现彻底爆干净了。再加上这个题有 6 个方向,又要数格子。瞬间那种被 8边形 cave 支配的玉玉症发作了,然后我就把这个题扔给小邱老师了。

怀疑我后面可能在摸鱼,最后就小邱老师单刷 canal view,但是右下角还是修不对,tapa 那边好像是一定对的,然后我们搁那调整 SLICY 的解。

最后的得分是少了 3 个 quad,好像是 canal view 和 SLICY 对上的 quad 没对,加上 canal view 上面的 quad 也有点小错。

Team Round C: Reunion

机制比较复杂的轮。听说大家都不会做 Lohkous,然后我就被分配到了 W 组。我好像根本不知道别的组的题(?)感觉我好像又是混子。

这里的中间过程可能编的有点全错,做完 fact check 我再来更新一下。 找戴老师进行了一些简单的事实核查。

一开始的 countries 比较简单,然后做了一下很快发现某一个组(可能是 C)是个 domino,然后戴老师就迅速进 C 了。然后 P 也很快画出来了,小邱老师就进去了。我和 炜凡老师 继续做这个 countries,后面好像数错了格子,但是做了一会儿调对了,又仔细检查了一下。我就进了 W,炜凡老师和戴老师一起进了 C。

后面我就基本上单机 W,一开始我做这个 galaxies,然后发现根本对不上那个块,没有半句真话,然后发现抄格子少抄了两格(?)

然后做了会儿,就爆了,虽然做的时候基本上是逻辑的,但大盘感觉很容易看漏,就先放到一边了。然后我去做 Lohkous 了,马上找到了 W 块对应的地方,又发现不会做(?)然后又扔了。去做 Araf,好在 Araf 比较简单,迅速做出来了。然后 Shape Division 做了一会儿,也做出来了。

期间戴老师的 C 区只剩个 shape division 了,然后分比较低就扔了,去做 S 区了。炜凡老师过来,来支援我的 galaxies,可能把我做的全擦了之后重新做了一下就做完了。然后听说小邱老师单刷完了 P 区,和戴老师一起去做 S 了,有点太伟大了。

然后我发现我的 Lohkous 又少抄了两格(???)抄完之后,感觉做得比较顺。中间有一些比较 tricky 的块,但因为经过过 toketa 的洗礼,虽然忘了很多,但还是比较顺利的做完了。

炜凡老师做完 galaxies 之后就去开大拼图了。然后我也进来了。但感觉我好像是混子,最后基本上就是小邱老师做完 P 区之后疯狂 carry,拼了比较多的块。其实拼到后面就有俩大的 5x6 和 4x9 好像无法同时放进去了,但是也没有啥时间了,基本上对了挺多的。

然后听说小题错了俩 300,再错了俩 300 的情况下(但怎么不能被 50 整除了???),我们好像只比 JPN-A 低了 75 分。拼图可能就 10 块左右没有拼进去。其实发挥的非常非常好了,贷款第一名。怀疑队友们在偷偷 carry。

Team Round D: Marathon

前面三轮做的其实挺爽的。好像是把出出来的 不太是题 的题目都放到这一轮了,所以是唯一一轮做的没那么爽的。

赛前就制定了策略,戴老师想去做最后一区的 one to X,因为我们队伍里有最好的数独选手们,所以不去做这个没啥道理?

赛前其实没有太分配题目,基本就是戴老师做 number 类,我做 loop & shade,小邱老师可能啥都会,并且很有感觉,就去做一些比较魔怔的题型,然后 炜凡老师 做一些比较传统的题型。如果我记错了任何一个人做的题,那就先对不起。

第一组我做了 yajilin 和啥来着,忘了。然后四个人一起做最后一个 akari,但是好像是这一轮唯一一个做错的。第二组我做了 heyawake 和啥来着,忘了。前面两组都做完了。

第三组我做了 lohkous,这个题很白痴,而且和 24hpc 的题目基本差不多。然后还有个 geradeweg。然后炜凡老师卡 pentominous,但这个题感觉很魔怔,其实不太好做。后面因为大家都做完了就扔了。

第四组好像全错了。我先去做了 vertigo,然后全错了。就扔给小邱老师了。小邱老师好像迅速拿下了 hidato。戴老师和炜凡老师对着 Simple Gako 和 Statue Park 玉玉症,好像都没有做出来。然后我去做 scrin 了,小邱老师做 vertigo 也做倒闭了。后面大家感觉不对就想把这轮扔了。其实我的 scrin 只有下面可能四五个矩形没有画了,但是一时没有看出来,不知道上面有多少真话,最后也扔了。这一轮大家只做了一个题。

然后第五组,直接扔了。Nagenawa,Hashi (Cipher),Look-Air,Mintonette,Rectangle Slider 看起来是题的比较少。其实我想做 nagenawa 和 mintonette,但是因为别的题可能凑不出能做的,为了大局考虑就扔了。

第六组,我去做 masyu,这个 masyu 有一些 global 的大 deduction,比较难,其实 pc 群里面几个月前就有相关的讨论,但是我没看。但是我靠着感受那股劲儿,加上唯一性嗯猜,做出来了。然后戴老师和炜凡一起做 sukoro,也勉强做出来了。小邱老师在做 tren,但好像比较倒闭,感觉这个题如果调整可能道理不是很多,这个题可能我来做更加合适?fillomino(splitter) 大概感受到一定有两个角能 somehow 唯一,但没有一下子看出来。coral(fish) 也有一些连通性,但感觉也没有完全悟到。随着老师们做完了 sukoro,大家就把剩下的题扔了。

第七组,我去做 Slitherlink(Knapp Daneben),然后小邱老师做 dbchoco,戴老师做 falling letter,炜凡老师做 magnets。居然是,没人做 jsum?其实 falling letter 是 shading 题型,感觉我来做能更快一点?然后别的老师们比较快的把剩下的题做完了,slither 本来就比较肝,再加上在纸上 trial 起来比较慢。不过还好别的老师都做完的时候,我几乎做了大半盘。然后老师们尝试了一下最后的 jsum,等我把这个题做完。我们就把最后的 jsum 扔了。第七组其实性价比非常高,几个题都是那种花时间就能做出来的题,不确定性比较低。

然后我们就来到了第八组,可能留了 15 - 20 分钟。第八组其实可做的题不多,我开局去做 600 分的 letter weights,但是直到比赛结束,以及赛后做了很久,都没有任何进展。然后炜凡老师做 magnets,戴老师做 1到x,小邱老师做蛇。然后小邱老师极快的时间做完了蛇,之后就和戴老师一起 1到x。其实赛后很多选手发现这个蛇没有看起来那么难,只是他们没有开第八轮而已。感觉我们队伍里面有最好的数独选手,所以做不出 1到x 也没啥道理。最后两位老师一起合作,成功的做出了 1到x。

最后这轮出来,我们也只比 JPN-A 低了 300左右。JPN-A 好像把前面的题几乎做完了,但是我们靠着策略,开到了第八组,拿到了比较不错的分数。感觉这一轮就是虽然大家个人实力可能没有那么强(?),但是因为技能点比较各异,加上戴老师对拿下 1到x 充满了信心,所以很好的能够适配这些题,拿到比较不错的分数。

感觉 team round 差不多治好一些玉玉症。至少感觉 team round(除去最后一轮)从题目到时长设置的都非常的科学。对我们队来说,少 10 分钟可能就会会少完成很多。多 10 分钟,可能就能做完了,少了那种最后时刻乱做的刺激感。题目的设置也没有一些特别困难的卡点,老师们能够比较愉快地各展所长,分工合作,我能比较愉快地浑水摸鱼,滥竽充数。

Individual Playoffs

关我屁事。

后记

再说。

The 2024 ICPC Asia East Continent Online Contest (I) ~~部分~~题解

2024-09-17 17:59:46 By bulijiojiodibuliduo

A. World Cup

首先注意到,我们把自己的队伍的能力值设成 0,把比自己强的队伍能力值设成 1,比自己弱的队伍能力值设成 1,那么最后能达到的最优排名只和自己在所有的队伍中排名多少有关。

也就是只需要预处理出自己是 32 支队伍中第 k 名,那么最后的结果是多少即可。这个可以直接搜索即可,枚举每组有多少个 11,然后根据赛程安排模拟。也可以直接手玩。

时间复杂度为 O(q)

B. Graph

首先条件等价于,对于每个数字 d,所有 d 的倍数的点形成的导出子图一定是连通的。

  • 必要性:考虑 d 和它的所有倍数即可。
  • 充分性:如果 (u,v)=d,从 u 先走到 d,然后走到 v 即可。

从大往小考虑每个 d,令 m=n/d,并且对于每条边 u,v ,我们认为它是在考虑到最大公约数 (u,v) 时候被加入的。考虑 d 的倍数的点的导出子图。假设新的图 G 里面的标号为 1,2,,m 的点,分别为原图里 d,2d,,md 的点。

注意到根据之前连的边,G 里有一些点已经连通。

  • 如果一个数是合数 x=px,其中 px 的某个素因子,那么 xp 连通。
  • 如果一个数是素数 p 且不超过 m/2,那么 p2p2,也就是可以通过 2p2 连通。
  • 如果一个数是素数 p 且超过 m/2,那么在这个图 G 中,它不会和其他任何点连通。

也就是 G 中的连通块为 1,所有大于 m/2 的素数,以及其他点。因为需要连的边最少,那么我们会将这些点连一个生成树。方案数可以通过类似完全图生成树的方法计算,即:

  • 如果有 k 个连通块,大小分别为 x1,x2,,xk,那么生成树的个数为 xk(xk)k2

如果对于 m,它的方案数为 fm,那么答案为 ni=1fn/i,可以用数论分块的方法解决。

我们要注意到计算 fm 的时候,还需要统计大于 m/2 并且不超过 m 的素数个数,这一部分需要用到一些素数筛相关的方法,大家可以参考 OIWiki 或者 Atcoder

前面筛素数的时间复杂度为 O(n3/4/logn),所以总的时间复杂度就是这个。

C. Permutation Counting 4

问题等价于 (li1,ri) 这个图是不是棵树。

从线性代数的角度考虑,假设有个矩阵 Ai,j=[j[li,ri]],等价于要求 per(A)mod,而 \text{per}(A) \equiv \text{det} (A) \pmod 2,那么考虑这个矩阵的行列式即可。

对于这个矩阵,我们可以在左边和上面补上一行一列,并且除了左上角的位置是 1,其他位置都是 0。然后依次从前往后,执行每一列减去后一列的操作(类似差分)。那么操作完之后,对于每一行 1\leq i \leq n,有 A_{i, l_i-1} = -1, A_{i, r_i} = 1,其他位置都是 0

那么如果 (l_i-1, r_i) 这些边成环,那么把这些边对应的行拿出来,一定是线性相关,也就是行列式为 0

否则可以根据行列式的定义展开,那么恰好会有一项是非零的,也就是行列式为 \pm 1,即模 2 的余数为 1

时间复杂度为 O(n)

D. Protection War

我们把所有极长的的非零区间当成一段。首先可以证明,如果每一轮模拟时间复杂度是 O(段数),那么总的时间复杂度为 O(n + q\sqrt{n})

证明可以考虑势能分析,长度前 T 大的段当成长段,剩下的当成短段。势能 S 看成所有短段的长度的和,短段长度不超过 n/T

  • 一号操作可能会分裂一段,那么 S 会增加不超过 n/T
  • 二号操作相当于合并若干段,如果合并之后的段为长段,那么 S 不会增加,否则因为长度不会超过 n/TS 的增加量也不超过 n/T
  • 最后的修改操作,对于这些短段,如果操作了,那么对应的长度会减小,这部分会摊在势能中。

所以每次操作,势能的增量不超过 n/T,对于长段操作的代价可以额外计算,不超过 T,当 T=\sqrt{n} 时,可以证明这部分时间复杂度不超过 O(n+q\sqrt{n})

那么我们可以每一轮用 O(段数) 的代价直接模拟,需要支持区间加,区间求和,单点修改等操作。如果直接使用线段树等数据结构,那么时间复杂度为 O((n+q\sqrt{n})\log n),不一定能通过。

注意到区间求和操作的次数是 O(q) 的,而区间加和单点修改操作的次数是 O(n + q\sqrt{n}) 的,那么可以使用根号数据结构把修改部分做到 O(1),查询部分做到 O(\sqrt{n}) 即可。

这里还有个细节问题是每次对每段做把最后一个数改为 0 的时候,需要 O(1) 查询,也就是不能直接用数据结构查询这个数的值。我的做法是维护了整个序列的差分,以及每一段最后一个数的值,那么可以通过差分快速算出前一个数的值。

时间复杂度为 O(n+q\sqrt{n})

E. Random Dungeon

首先把所有数从大到小排序。我们的策略一定是对于第一轮,我们会设定一个阈值 t_1,如果抽到的牌是全局前 t_1 大,那么直接结束,否则继续抽取。对于第二轮,我们继续会设定一个阈值 t_2,后续轮次依次类推。这些阈值的设定与抽到了什么牌无关,并且是单调不增的,也就是 t_1 \geq t_2 \geq \dots \geq t_n

一个比较符合直觉的的理解为:如果抽了 k 轮还没结束,意味着前面抽的牌的排名都是大于 t_k。从后面的轮次来看,再抽到这些牌也会继续,所以都是垃圾牌,也就意味着后面的策略和具体抽了哪些牌无关。并且到后面的轮次还没结束,意味着我们前面扔掉了一些垃圾牌,那么剩下的牌会更偏向于好牌,所以阈值会相应的提高。

严谨一点的证明再说。

这样可以得到一个 O(n^2)dp,即令 dp[i][j] 表示还剩 i 张牌,当前极长没有被选中的前缀为 j 的最大期望收益。那么有转移

dp[i][j] = \frac{i-j}{i} \times dp[i-1][j] + \frac{1}{i} \sum_{k=1}^j \max(dp[i-1][k-1], a_k) - c

含义为如果选中的不是前 j 个,之前已经扔掉了 j+1,那么这个一定会扔掉,否则考虑扔掉继续做或者直接选择 a_k

对着这个式子直接优化是困难的。继续考虑组合意义,根据前面的假设,在最优策略下,如果剩下 i 张牌,那么这些牌一定是一个前缀加上垃圾牌,那么这个时候的最大期望收益和前面抽了什么牌没有关系,所以可以等效为剩下前 i 大的。

dp[i] 表示还剩前 i 大的牌的最大期望。考虑当前的决策为如果抽到前 j 大的就停止,否则继续抽。那么有转移

dp[i] = \max_{j=1}^i \frac{\sum_{k=1}^j a_k + dp[i-1] \times (i - j)}{i} - c

也就是选 a_j\geq dp[i-1] 的最大位置即可,这也是倒数第 i 轮对应的阈值。

dp 可以用单调性做到 O(n)

F. Make Max

首先注意到,如果操作的时候选了大于两个数,那么把它变成从最大值开始,每次修改相邻的数,这样一定不劣,也就是每次操作会选择相邻两个数。

其次注意到,如果一个数变成了全局最大值,那么就无法继续操作,所以可以把保留全局最大值,先递归左右两边,然后最后操作全局最大值。

我们可以通过建笛卡尔树来模拟这个过程,每个数的操作次数也就是这个数到根的路径上不同的数字个数。

时间复杂度为 O(n)

G. The Median of the Median of the Median

首先可以二分,判断答案是不是大于等于 X,那么我们可以把大于等于 X 的数字当成 1,小于 X 的数字当成 -1。那么一个集合的中位数大于等于 X 当且仅当它们和大于 0

所以题目中的操作都可以用前缀和求每个集合的和,在 O(n^2) 解决。时间复杂度为 O(n^2 \log n)

H. Rainbow Bracket Sequence

问题相当于 n 个左括号,你需要分配给这些位置,并且要求:

  • i 种颜色个数不小于 l_i
  • 2i - 1 个位置左括号个数不小于 i

使用上下界最大费用流解决。建立一个源点 S,对于每个颜色建立一个点 b_i,对于整个序列建立一排点 a_1, \dots, a_{2n+1}, 。我们连这些边(下面括号里三个值分别表示下界,上界,和费用):

  • Sb_i(l_i, \infty, 0) 的边,表示每种颜色的下界。
  • b_{c_i}a_i(0, 1, v_i) 的边,表示如果这个位置放左括号,那么需要 v_i 的费用。
  • a_ia_{i+1}(\lceil i/2\rceil, n, 0) 的边,表示前面至少需要这么多个左括号。
  • a_{2n+1}T(n, n, 0) 的边,表示一共需要恰好 n 个左括号。

跑最大费用流即可。

时间复杂度为 O(\text{maxcostflow}(n, n))

I. Boxes

首先可以发现,如果所有的点集形成的凸包都是嵌套的,那么一定更优。

证明 by 修噶:考虑最外层的若干个凸包,假设多于一个,则使用这些凸包的凸包代替这些凸包,显然点数减少,体积增大,且不影响内部方案。所以一层层剥凸包是最优的。

那么你需要做的是不断重复,先求出这个点集的凸包,然后删除,接着继续执行这个操作,直到剩下的点不超过 3 为止。

假设一层凸包上会有 d 个点,那么一些常见的三维凸包算法(比如卷包裹)时间复杂度其实是 O(nd) 的。那么你只需要暴力做这个过程即可,这些凸包上点数一共是不超过 n 的,也就是时间复杂度为 O(n^2)

注意:这个题答案可能会超过 long long 的数据类型。

J. Rivals

好像是生成函数爆算一下,没意思的,别做了。

修噶题解

K. AC Automation Chicken

如果知道了哪个点为根,那么 Trie 上的边会从根往外连,而 fail 边会朝根连,那么从根节点出发 BFS 就可以确定哪些边是 Trie 上的边。那么可以相对简单得判断和构造,具体细节见下。

考虑根节点具有什么性质。假设 u 为根节点,v 为它的一个儿子节点,那么图里面会有 (u, v)(v, u) 这两条边,即分别为树边和对应的 fail 边。下文把 (u, v)(v, u)都存在的边叫做双向边。

对于一条双向边 (u, v),如果这两个点都不为根节点,那么根据 AC 自动机的性质可以得到这个节点对应的字符串包含的字符一定是相同的。假设路径为 r \to v_1 \to \dots \to v_k,那么对应的 fail 边为 v_k \to v_{k-1} \to \dots \to v_1 \to r。所以一个合法的 AC 自动机的双向边会形成一个类似菊花图的结构,从根节点出发,往外若干条链。

如果这个菊花图中存在一个大于等于三度的点,那么这个点一定是根节点,否则会形成一条链。对于一条链,每个点都可能是根节点,比如字符串 aaa, bbb 和字符串 aaaaaa 形成的 AC 自动机是同构的。

首先特判一下,整个图是一条链,那么任何一个点作为根节点都是合法的。否则假设根节点 r 左右两边的点分别是 u, v(如果左右两边的点不存在也同理),即这三个点形成 u \leftrightarrow r \leftrightarrow v 的结构,不妨设 u, v 对应的字符为 1, 2。那么考虑 u 这个子树的最浅的分叉,也就是不在双向边的链上的点。

  • 如果对应的字符为 1,那么还是双向边,矛盾。
  • 如果对应的字符为 2,因为是最浅,那么会指向 v
  • 如果对应的字符不为 1, 2,因为最浅,会指向 r

也就是如果指到了链上,那么根节点一定是这个点本身,或者这个点在链上的邻居节点。同样的,对于链上任意一点 x,指向了一个不在链上的点 yy 指向了一个在链上的点 z。可以通过类似的分析得到根节点一定是 z 或者 z 的邻居,那么只需要检查 O(1) 个点能否成为根即可。

判断一个点为根是否可行,首先根据上文说的,可以通过 BFS 区分树边和 fail 边。其次,对于每个点,如果它的 fail 边指向根节点,那么可以给它一个新的字符,否则与 fail 边指向的点对应的字符相同。最后需要判断它的 fail 边是不是真的指向那个点,这个可以通过对这个 Trie 建一遍 AC 自动机判断。但是由于字符集大小为 O(n),所以建立 AC 自动机需要可持久化线段树或者其他方法辅助,并不是特别方便。一个简便方法是假设这个点字符等于 c,那么等价于判断沿着父亲的 fail 边往上跳,第一个等于 c 的儿子等于这个点的 fail。那么可以通过在 fail 树上 dfs,然后对每个字符 c 用一个栈记录一下上一个等于 c 的儿子在什么地方。这样就可以做到 O(n) 判断。

这个题还有很多细节,包括但不限于:

  • 没有重边自环。
  • Fail 边需要指向深度更浅的点。
  • 图需要连通。
  • Trie 里每个节点的儿子字符集需要不同。
  • 等等

如果用 Hash 表之类的方法找双向边以及判断重复,那么这个题可以做到 O(n) 的时间复杂度。

L. Bull Farm

考虑对于每个操作,我们的空格会怎么移动。

  • 如果一个操作不同的位置不超过 n-2,那么一定会有两个元素到同一个地方,那么是不合法的,可以直接忽略。
  • 如果不同的位置等于 n,那么也就是形成若干个环,即 i \to p_i,有因为它是个环,也就是操作若干次能回到原点,所以可以把这些边看成双向边。
  • 如果不同的位置等于 n-1,假设 x_1, x_2 是指向同一个位置的两个数,y 是缺失的位置,那么等价于 x_1 \to y, x_2 \to y

每个查询等价于用不超过前 k 轮的边,a 能否到达 b

对于无向边,我们只需要在从前往后加入的过程中,保留会改变连通性的边即可,那么不会超过 O(n) 条。有向边一共 O(l) 条,也就是图里面的边,只需要保留 O(n + l) 条。

对于每条边的边权设成加入的时间,那么问题变成了需要求两个点之间的权值最大边最小的路径。这个可以对于每个起点,用类似 Dijkstra 的做法解决,因为值域比较小,所以可以用若干个桶的做法做到线性。也可以按时间从小到大依次加入边,然后从加入的这条边开始 BFS,求出新的可达的点。

这两种做法都是线性的,总的时间复杂度为 O(n(n+l) + q)

M. Find the Easiest Problem

按照题意模拟即可。

共 2 篇博客