A

B

把奇数和偶数拿出来分别排序,然后按下标归并,看看得出的结果是不是排好序的。

C

如果头尾同色,就找有没有 \(k\) 个位置和头尾同色;

否则从头找 \(k\) 个和头同色的,然后再在这之后找 \(k\) 个和尾同色的。

D

把每个前缀和相邻的相减,得出的结果:

  1. 有大于 \(n\) 的,拆成两个没出现的数相加;

  2. 有重复的,把其中一个拆了;

  3. 没有重复的且在 \(1\sim n\) 内,肯定在尾巴处补一个。

如果有两个大于 \(n\),或者两对重复,或者大于 \(n\) 的和重复的都有,那就不可行。

如果发现拆了之后不能构成排列,也不行。

E

赛时没看见无环

就是一个类似拓扑排序/深搜的题。从无限的药出发,不停更新。每种药可以混合(找前驱)/买。

F

法一:

考虑每个位单独看。如果 \(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}\) 产生答案。

之后的事情就是排一下序就行。

G

观察发现,\(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)\) 的。不会超时。

随机推荐

  1. 【MLA】一种内存泄漏分析方法

    项目地址:skullboyer/MLA (github.com) 介绍 MLA 即 Memory Leak Analyzer,是一个排查内存泄漏的分析器 实现机制是在malloc时记录分配位置信息,在 ...

  2. cancal报错 config dir not found

    替换classpath中间封号两边的值

  3. Oracle 监控客户端的连接数量趋势

    Oracle 监控客户端的连接数量趋势 背景 前期简单总结了table方式将表信息展示出来的方法 但是感觉这样非常不直观. 想着能够做出一个趋势来. 时序数据库的最佳的使用方式. 之前的确是太靠自己的 ...

  4. [转帖]038-拯救大兵瑞恩之 TiDB 如何在 TiKV 损坏的情况下恢复

    https://tidb.net/blog/4b5451bb?utm_source=tidb-community&utm_medium=referral&utm_campaign=re ...

  5. FIO的再学习-不同Raid,不同磁盘性能验证

    FIO的再学习-不同Raid性能验证 背景 发现自己对iodepth的和num_jobs的理解存在偏差 找了一些资料才发现自己很多地方做的不对. 这里找到一个新资料可以进行模拟数据库的测试 测试配置文 ...

  6. 【转帖】linux 软连接的使用

    https://www.cnblogs.com/sueyyyy/p/10985443.html 软连接是linux中一个常用命令,它的功能是为某一个文件在另外一个位置建立一个同不的链接. 具体用法是: ...

  7. [转帖]如何优雅的使用 Systemd 管理服务

    https://zhuanlan.zhihu.com/p/271071439 背景:我们在构建 Kubernetes 容器化平台时,会在节点上部署各种 agent ,虽然容器化当道的今天很多程序可以直 ...

  8. 测试角色在项目各阶段的项目管理tips

    作者:京东物流 宋雪薇 1 前言 项目管理是一个繁杂的过程,每个阶段需要涉及到不同人员.资源的协调配合.每个角色都有自己的定位和任务,为了紧密配合项目经理或无分配项目经理运行项目的场景下确保项目成员共 ...

  9. echarts饼状图自定义legend的样式付费

    先看效果图 代码 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> < ...

  10. 每日一库:使用Viper处理Go应用程序的配置

    在开发Go应用程序时,处理配置是一个常见的需求.配置可能来自于配置文件.环境变量.命令行参数等等.Viper是一个强大的库,可以帮助我们处理这些配置. 什么是Viper? Viper是一个应用程序配置 ...