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. MADE: Masked Autoencoder for Distribution Estimation

    目录 概 主要内容 代码 Germain M., Gregor K., Murray I. and Larochelle H. MADE: Masked Autoencoder for Distrib ...

  2. Spurious Local Minima are Common in Two-Layer ReLU Neural Networks

    目录 引 主要内容 定理1 推论1 引理1 引理2 Safran I, Shamir O. Spurious Local Minima are Common in Two-Layer ReLU Neu ...

  3. [C]郝斌C语言课程大纲及笔记

    本笔记整理于郝斌老师C语言课程,做学习参考之用. 1.[编程笔记]第一章 C语言概述 2.[编程笔记]第二章 C语言预备知识 3.[编程笔记]第三章 运算符与表达式 4.[编程笔记]第四章 流程控制 ...

  4. 云南农职《JavaScript交互式网页设计》 综合机试试卷③——实现二级分类菜单

    一.语言和环境 实现语言:HTML,CSS,JavaScript,JQuery. 开发环境:HBuilder. 二.题目(100分): 使用Jquery和JavaScript实现二级分类菜单管理 点击 ...

  5. SpringBoot集成log4j,解决log4j.properties不生效问题

    Spring Boot集成log4j其实比较简单,maven的话,在xml中增加log4j依赖就行 <dependency> <groupId>org.springframew ...

  6. 一文让你明白Redis持久化(RDB、AOF)

    为什么要持久化 Redis是内存数据库,如果不将内存中的数据库状态保存到磁盘中,那么一旦服务器进程退出,服务器的数据库状态就会消失(即断电即失).为了保证数据不丢失,我们需要将 内存中的数据存储到磁盘 ...

  7. iOS微信支付无法直接返回APP的问题

    最近新测个项目,发现在IOS手机的APP上使用微信支付无法直接返回APP. 咨询微信客服,了解到无法直接返回APP的原因是收款配置的APPID为合作商家的APPID,而不是公司APP的APPID. 当 ...

  8. Java|从Integer和int的区别认识包装类

    https://blog.csdn.net/darlingwood2013/article/details/96969339?utm_medium=distribute.pc_relevant.non ...

  9. JSch Algorithm negotiation fail

    https://stackoverflow.com/questions/30846076/jsch-algorithm-negotiation-fail As you can see, the ser ...

  10. github 创建网络仓库 ,使用git工具将本地文件上传/删除 --- 心得

    1.前言 使用  git做项目控制版本工具,当然,使用SVN也可以,但是,git让人感觉更先进一些,与GitHub结合,用起来很方便,服务端由官网控制. 而SVN分客户端和服务端,都是个人控制,因此, ...