【学习笔记】模拟赛翻车记
心债
菜肴制作
- 题目让你把编号最小的尽量最先输出
- 显然不能直接贪心每次取出编号最小的点
否则第二个样例会wa掉- 然后这题有有一个巧妙的思维那就是建立反图
- 我们考虑编号最小的这个点,首先它在反图中连向的点都是在原图中限制它的点,我们按反图跑的拓扑序中这个编号最小的点一定在它们前面
- 其次我们希望这个编号最小的点最后被取出,也就是说当前局面下所有其他的点都被这个编号最小的点所限制
- 我们想到每次取出编号最大的节点
- 对于编号次小点我们同样可以作类似讨论,那就是除了编号最小点外其他点都被编号次小点所限制
- 因此我们按反图建边,每次取出编号最大的点,再把得到的拓扑序翻转就是答案
序列
- 首先对于一个区间 [ l , r ] [l,r] [l,r]我们可以贪心地求出最后剩下的两个数使得操作序列的倒序字典序最小
- 但是有一个性质我分析错了那就是我以为只能编号大的点连向编号小的点
- 虽然我们找的是区间 [ l , r ] [l,r] [l,r]能留下来的最小值但是由于奇偶性的问题递归下去会产生编号更小的点导致我们误以为这个点很优,实际上这个编号小的点挂着一个编号极大的点导致最后倒序字典序被这个编号极大的点影响了
- 然而这题我们完全可以规避掉这个问题
- 显然我们可以直接用堆维护,每次取出剩下的编号最小的区间然后分裂出一些小区间
- 这样我们得到的其实是倒序的操作序列
- 同时这种做法不存在拓扑排序的问题堪称完美
看来死的不冤枉- 复杂度 O ( n log n ) O(n\log n) O(nlogn)
还是不要自以为是了罢- 总结一下要求哪边最小就从哪边跑拓扑
基因进化
一看时限 1 s 1s 1s就知道大事不妙然后多一个 log \log log被卡飞了看来数据结构把人学傻不是假话- 显然你看这个东西就是在首尾插入字符然后问你一段东西的 hash \text{hash} hash值
- 当然有两个字符串比大小的操作然后把开头和结尾删一段字符
- 直接模拟就行了用啥线段树啊
- 复杂度 O ( n log n ) O(n\log n) O(nlogn)
- AC Code:
陵陵曾玩的位运算题
什么玩意儿
啊竟然是人类智慧!!
原来模拟题是没得套路滴。
如果 x x x的二进制位上 1 1 1的个数比较少,直接预处理 f [ y ] f[y] f[y]表示集合中的数与 y y y等于 y y y的个数,然后容斥得到与 x x x等于 y y y的个数。复杂度 3 k 3^k 3k
如果 x x x的二进制位上 0 0 0的个数比较少,那么可以从高位到低位,按位确定答案的每一位。如果当前考虑的位置是 0 0 0,那么集合中的数这一位是 0 0 0或 1 1 1都是没有影响的,因此两种情况都要考虑。显然可以在 trie \text{trie} trie树上暴力,复杂度 2 17 − k × 17 2^{17-k}\times 17 217−k×17。当然子树为空可以直接跳出来,所以跑不满。
通过合理设置阈值可以通过本题。取 k = 7 k=7 k=7即可。
__EOF__

本文链接:https://www.cnblogs.com/cqbzly/p/17530114.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· DeepSeek 开源周回顾「GitHub 热点速览」
2021-07-22 【模版】组合数学