A

可以发现不论往怎样一个串往后加上两个 \(0\) 或两个 \(1\) 其奇数位和偶数位上的差值都是相同的。因此我们两位两位考虑这个 \(01\) 串,对于相邻两位相同那么直接留下,否则留下 \(0\) 即可。

B

每轮直接贪心找一个能使得当前 \(\gcd\) 最大的数往后填即可。

C

为了能找到每个数的取值,我们的第一想法就是找到 \(p_i = n\) 的位置,然后用剩下的数去依次模 \(p_i\) 即可。但你会发现这个 \(p_i = n\) 的位置是很难找到的,但上面这个过程给予了我们提示:对于排列中任意两个数 \(p_i, p_j(p_i < p_j)\),\(p_i \% p_j = p_i, p_j \% p_i < p_i\)。因此,每次我们查询两个位置 \(p_i \% p_j, p_j \% p_i\) 则其中小的哪个数一定为 \(p_i\),但 \(p_j\) 的值并不确定,因此我们还需记录下 \(p_j\) 等待后面的查询。于是我们可以从左到右扫过来,假设当前扫到了 \(i\) 号位置,记录 \(1 \sim i - 1\) 中最大元素的位置 \(j\),每次查询 \(p_i \% p_j, p_j \% p_i\) 即可。最后留下来的哪个数一定最大为 \(n\)。这样的查询次数不超过 \(2n\)。

D

首先可以注意到一个 \(dp\),令 \(dp_i\) 表示跳到 \(i\) 的最小步数,那么有朴素的转移:

\[dp_i = \min(dp_i, dp_j + 1)(\max(a_{i + 1}, \cdots, a_{j - 1}) < \min(a_i, a_j))
\]
\[dp_i = \min(dp_i, dp_j + 1)(\min(a_{i + 1}, \cdots, a_{j - 1}) < \max(a_i, a_j))
\]

首先观察一下第一条转移,你会发现这个转移的条件是非常有特色的。也就是说对于每个 \(i\),其能转移到的 \(j\) 要满足 \(j + 1 \sim i - 1\) 中不存在位置大于等于 \(a_i, a_j\)。换句话而言,也就是 \(j\) 右侧第一个不小于其的位置要不小于 \(i\),并且 \(j\) 也要不小于在 \(i\) 左边第一个不小于其的位置。但这样的限制还是很空泛,依然不能有效加速这个过程。仔细分析一下你会发现,如果 \(i\) 在 \(j\) 右侧第一个不小于 \(a_j\) 的位置左侧,那么一定有 \(a_i < a_j\),显然 \(i\) 左侧第一个比他大的位置一定就是 \(j\);反过来另一种情况就一定可以推得 \(j\) 右侧第一个不小于其的位置一定为 \(i\)。这样转移的次数就会被大大减少了,可以发现能转移到 \(i\) 的位置 \(j\),就是 \(j\) 为 \(i\) 左侧第一个比他大的位置或 \(j\) 右侧第一个不小于这个位置的位置为 \(i\) 的这些 \(j\)。显然上述两个位置可以在单调栈时求出,并且对于第二条转移方程有类似的转移,于是本题就在 \(O(n)\) 的时间复杂度内被解决了。

E

直接按照每条边去确定每个点填的颜色显然是很难做的,因为我们不知道这个点对后面有什么影响,因此需要换一个方向考虑。

我们可以发现 \(n\) 号点不能被到达需要关注于 \(i \rightarrow n\) 的所有点 \(i\)。一个直接的想法是如果 \(i \rightarrow n\) 的边权只有 \(w\) 那么我们一定要把 \(i\) 号点设置为 \(!w\) 会更优。实际上这个想法是正确的,因为:

不论之前到 \(i\) 号点的边怎么选择,都只有到达 \(i\) 号点和不到达两种情况。如果 \(i\) 号点不可到达,显然选择什么都无所谓;如果 \(i\) 号点可到达,那么如果不选 \(!w\) 就一定会到达 \(n\) 了,但选择 \(!w\) 还又可能到不了 \(n\),因此选 \(!w\) 会更优。

于此同时你会发现如果 \(i \rightarrow n\) 的边权 \(0 / 1\) 都有,那么同样利用上面哪个分析过程你会发现选择 \(0 / 1\) 都是无所谓的,因为不论选择什么都能到达 \(n\)。

接下来我们需要从 \(n\) 连到的边回到整张图,你会发现上面的过程给了我们很大的提示去将这张图的所有边反向,那么我们接下来将这张图反向过来看。你会发现假如当前还是有一些点能到达 \(n\),那么如果我们要使这些点都不能到达,显然选择先后考虑的顺序是不会影响结果的。退一步讲,如果存在其中一些点是怎样都可以到达的,那么我们的任务是需要最大化整张图的最短路。那么我们肯定要贪心地让最短路最小点能到达的边断掉,否则经过这个点点必然可以变为最短路。并且由于先后考虑的顺序不会产生影响,因此我们直接贪心选取当前最短路最小的点出来让它所连的边能断则断,再将不能断的点加入当前考虑的范畴即可。因为边权大小都是 \(1\) 的,于是我们直接使用 \(bfs\) 实现即可。时间复杂度 \(O(n + m)\)。

CF Round #669 Div2的更多相关文章

  1. CF Round #580(div2)题解报告

    CF Round #580(div2)题解报告 T1 T2 水题,不管 T3 构造题,证明大约感性理解一下 我们想既然存在解 \(|a[n + i] - a[i]| = 1\) 这是必须要满足的 既然 ...

  2. CF round #622 (div2)

    CF Round 622 div2 A.简单模拟 B.数学 题意: 某人A参加一个比赛,共n人参加,有两轮,给定这两轮的名次x,y,总排名记为两轮排名和x+y,此值越小名次越前,并且对于与A同分者而言 ...

  3. [CF Round #295 div2] C. DNA Alignment 【观察与思考0.0】

    题目链接:C. DNA Alignment 题目大意就不写了,因为叙述会比较麻烦..还是直接看英文题面吧. 题目分析 经过观察与思考,可以发现,构造的串 T 的每一个字符都与给定串 S 的每一个字符匹 ...

  4. [CF Round #294 div2] E. A and B and Lecture Rooms 【树上倍增】

    题目链接:E. A and B and Lecture Rooms 题目大意 给定一颗节点数10^5的树,有10^5个询问,每次询问树上到xi, yi这两个点距离相等的点有多少个. 题目分析 若 x= ...

  5. [CF Round #294 div2] D. A and B and Interesting Substrings 【Map】

    题目链接:D. A and B and Interesting Substrings 题目大意 给定26个小写字母的权值,一共26个整数(有正有负). 给定一个小写字母组成的字符串(长度10^5),求 ...

  6. A. Grasshopper And the String(CF ROUND 378 DIV2)

    A. Grasshopper And the String time limit per test 1 second memory limit per test 256 megabytes input ...

  7. A. Alyona and Numbers(CF ROUND 358 DIV2)

    A. Alyona and Numbers time limit per test 1 second memory limit per test 256 megabytes input standar ...

  8. CF Round#436 div2

    额,这次的题目其实挺智障的.所以通过这次比赛,我也发现了自己是一个智障.... 不说太多,说多是泪... A. Fair Game 题意:给你一个数组,看你能否把它均分为两个所有元素均相同的子数组. ...

  9. CF Round #569 Div2(contest1180)

    比赛链接:http://codeforces.com/contest/1180 Problem A 题意:给出n,问方块数.看图理解... Solution: 找一找规律就可以了,发现方块数为2n*( ...

随机推荐

  1. Google Chrome调整控制台的位置

    众所周知,控制台是开发必备的工具,学会流畅的使用控制台会给我们的开发带来不一样的体验,但是控制台的位置有时却是困扰我们的一件事,控制台默认是在浏览器内,有时十分妨碍我们,那么有没有什么办法修改控制台的 ...

  2. Certified Adversarial Robustness via Randomized Smoothing

    目录 概 主要内容 定理1 代码 Cohen J., Rosenfeld E., Kolter J. Certified Adversarial Robustness via Randomized S ...

  3. BAIRE ONE FUNCTIONS (Baire第一类函数)

    目录 定义 导函数 一致收敛性质 的连续点 JOHNNY HU, BAIRE ONE FUNCTIONS. 一些基本的定义(诸如逐点收敛, 一致收敛\(F_{\sigma}\)集合等)就不叙述了. 定 ...

  4. CS5263替代PS176|设计DP1.4转HDMI2.0音视频转换线方案|PS176方案

    PS176是一个显示端口 (DP)至HDMI 2.0视频接口转换器适用于需要视频协议转换的电缆适配器.电视接收器.监视器和其他应用.它将接受任何显示端口输入格式,包括DP 1.1a.dp1.2a.dp ...

  5. 编写Java程序,创建一个父类交通工具类(Vehicles),以及两个子类,分别是轿车类(Car)和卡车类(Truck)。

    返回本章节 返回作业目录 需求说明: 创建一个父类交通工具类(Vehicles),以及两个子类,分别是轿车类(Car)和卡车类(Truck). 父类有属性品牌(brand)和颜色(color). 在父 ...

  6. 简单的 Shell 脚本入门教程

    Shell脚本 运作方式与解释型语言相当,如果有语言基础,学起 Shell 脚本就非常容易,但是 Shell 与常见的语言不同,一些常见的函数在 Shell 中需要组合一些命令得以实现 工具推荐 Sh ...

  7. Ranger开源流水线docker化实践案例

    1.背景 开发部门决定在Apache Ranger开源社区贡献代码,目标是个人国内排名Top1,世界排名Top2,并且在已经成为Ranger项目的Committer情况下,争取成为Ranger项目的P ...

  8. Kafka和RabbitMQ有哪些区别,各自适合什么场景?

    经常有人问我 有个 xx 需求,我应该用 Kafka 还是 RabbitMQ ? 这个问题很常见,而且很多人对二者的选择也把握不好. 所以我决定写篇文章来详细说一下:Kafka 和 RabbitMQ ...

  9. mysql数据库忘记root密码怎么办?

    mysql数据库忘记root密码怎么破解和修改 1.停止数据库的运行 [root@localhost ~]# /etc/init.d/mysqld stop 或者[root@localhost ~]# ...

  10. uni-app开发的h5,使用微信授权登录(前置条件+具体代码)

    原文 微信内嵌浏览器运行H5版时,可以调起微信登录 普通浏览器调起微信登陆是不开放的,只有个别开发者才有,比如京东 前置条件 在微信内嵌浏览器运行H5版时,调起微信登录,需要配置回调域名 (请注意,这 ...