CF1851
氵
把奇数和偶数拿出来分别排序,然后按下标归并,看看得出的结果是不是排好序的。
如果头尾同色,就找有没有 \(k\) 个位置和头尾同色;
否则从头找 \(k\) 个和头同色的,然后再在这之后找 \(k\) 个和尾同色的。
把每个前缀和相邻的相减,得出的结果:
有大于 \(n\) 的,拆成两个没出现的数相加;
有重复的,把其中一个拆了;
没有重复的且在 \(1\sim n\) 内,肯定在尾巴处补一个。
如果有两个大于 \(n\),或者两对重复,或者大于 \(n\) 的和重复的都有,那就不可行。
如果发现拆了之后不能构成排列,也不行。
赛时没看见无环
就是一个类似拓扑排序/深搜的题。从无限的药出发,不停更新。每种药可以混合(找前驱)/买。
法一:
考虑每个位单独看。如果 \(a_i,a_j\) 位上相等,那么 \(x\) 这一位应该和 \(a_i,a_j\) 的这一位相反。
建立 01 Trie。
枚举 \(i\),遍历 \(a_i\) 所有二进制位,如果当前位上有和 \(a_i\) 的位相等的分支,就必定走这个分支,同时把这一位对应的数累加进答案(这是贪心的想法,如果这里不选,即使后面 \(x\) 可以满足所有位,\(2^t> \sum_{x=0}^{t-1} 2^x\));否则就只有一条路可以走。
等走到了叶节点,我们就选好了 \(a_j\) 和 \(x\) —— 这是对于 \(a_i\) 的最大答案。
复杂度 \(O(nk)\)。
法二:
将 \(a\) 从小到大排序,下证最大答案一定是相邻的 \(a_i\) 产生。
排序后,假设答案不是相邻的 \(a_i,a_{i+1}\) 产生,那么必然是 \(a_i,a_j\) 产生,\(j-i>1\)。
若 \(a_i=a_j\),因为排了序,\(i<i+1<j\),\(a_i=a_{i+1}=a_j\)。\(a_i,a_j\) 产生的答案 \(a_i,a_{i+1}\) 也能产生。
否则 \(a_i,a_j\) 的二进制位一定有第一个不同的二进制位。由于 \(a_i<a_j\),所以这一位上 \(a_i=0,a_j=1\)。
此时 \(a_{i+1}\) 这一位上若是 \(0\),\(a_i,a_{i+1}\) 产生的答案必然比 \(a_i,a_j\) 更优;若是 \(1\),\(a_{i+1},a_j\) 产生的答案也更优。
矛盾。故一定是相邻的 \(a_i,a_{i+1}\) 产生答案。
之后的事情就是排一下序就行。
观察发现,\(h_i-h_j+h_j-h_k=h_i-h_k\),所以 \(i\rightarrow j\rightarrow k\) 的代价就等于 \(i\rightarrow k\) 的代价。
所以,点 \(i\) 能到达点 \(j\),只需要 \(i\rightarrow j\) 有一路径上的点高度均 \(\le h_i+e\) 即可。
注意到到达关系具有传递性,考虑并查集。
将所有询问离线,然后按照 \(h_{start}+e\) 从小到大排序,每次遇到一个询问,都把所有相互可到达的点并成一个块。
同时我们把所有边 \((u,v)\) 按照 \(\max(h_u,h_v)\) 从小到大排序。当此次询问 \(h_{start}+e=x\) 时,对于一条边 \((u,v)\),如果 \(\max(h_u,h_v)\le x\),那就可以合并 \(u,v\)。
等把所有边都合并完了之后,检查 \(start,end\) 是否在一个连通块内。
注意取出边合并两端的操作,不用每次询问都从头开始,所以总共是 \(O(m)\) 的。不会超时。
随机推荐
- C#语言 十大经典排序算法动画与解析!(动态演示+代码)(java改写成C# )
以下内容是根据 https://www.cnblogs.com/fivestudy/p/10212306.html 进行改写 排序算法是<数据结构与算法>中最基本的算法之一. 排序算法 ...
- java项目实战-tomcat-SpringMVC-基本用法01-day25
目录 1. maven创建 war项目 2. SpringMVC 1. maven创建 war项目 什么是jar项目 什么是war项目? jar项目: 由main方法来开始的 直接依赖JVM就能编译运 ...
- docker 资源限制之 cgroup
1. Liunx cgroup 使用 namespace 隔离运行环境,使得进程像在独立环境中运行一样.然而,仅有隔离环境还不够,还得限制被 namespace 隔离的资源.否则,namespace ...
- 通过 DBCA 创建 Oracle Database 21c 的进度停滞在 36%
1.问题 安装过程中一直卡在36% 检查 dbca 日志文件 位于 H:\app\trmbh\cfgtoollogs\dbca\ORCL\trace.log_2023-09-12_12-04-20PM ...
- NSSCTF Round#11 Basic 密码个人赛复盘
[NSSRound#11 Basic]ez_enc ABAABBBAABABAABBABABAABBABAAAABBABABABAAABAAABBAABBBBABBABBABBABABABAABBAA ...
- JMS微服务开发示例(九)相同的微服务,按用户所在城市来分配微服务器
虽然,默认情况下,多个相同的微服务,网关是自动根据微服务的压力情况,把用户请求分配到压力较轻的微服务器上. 但是,在某些业务情景下,我们可能希望人为去控制微服务的请求分配. 举个例子,我在北京.上海. ...
- [转帖]HBase实战:记一次Safepoint导致长时间STW的踩坑之旅
https://mp.weixin.qq.com/s/GEwD1B-XqFIudWP_EbGgdQ 过 程 记 录 现象:小米有一个比较大的公共离线HBase集群,用户很多,每天有大量的Ma ...
- [转帖]【测试】 FIO:ceph/磁盘IO测试工具 fio(iodepth深度)
目录 随看随用 NAS文件系统测试 块系统测试 FIO用法 FIO介绍 FIO 工具常用参数: FIO结果说明 I/O 的重放('录'下实际工况的IO,用fio'重放') fio工作参数可以写入配置文 ...
- Redis scan等命令的学习与研究
Redis scan等命令的学习与研究 摘要 背景跟前几天说的一个问题类似. 为了验证自己的设想, 所以晚上继续写脚本进行了一轮次的验证. 不过上次讨论时,打击好像都没听懂我说的 所以这次准备从基础开 ...
- 【K哥爬虫普法】辛苦钱被中间商抽走八成,还因此锒铛入狱
我国目前并未出台专门针对网络爬虫技术的法律规范,但在司法实践中,相关判决已屡见不鲜,K 哥特设了"K哥爬虫普法"专栏,本栏目通过对真实案例的分析,旨在提高广大爬虫工程师的法律意识, ...