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. Android物联网应用程序开发(智慧城市)—— 火焰监控界面开发

    效果: 布局代码: <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns: ...

  2. k8s loadbalancer与ingress实践

    k8s可以通过三种方式将集群内服务暴露到外网,分别是NodePort.LoadBalancer.Ingress,其中NodePort作为基础通信形式我们在<k8s网络模型与集群通信>中进行 ...

  3. Nginx入门--从核心配置与动静分离开始

    写在前面 优化我们项目,服务器部署,不仅仅可以是分布式,Nginx一样可以通过动静分离,负载均衡来减轻我们服务器的压力.Nginx的知识链,学习周期相对比较长,博主也是刚刚入门,这篇就先从实现基础的动 ...

  4. nginx中请求大小的限制的设置

    Nginx对客户端请求缓冲区大小有个默认限制,如果超过了该值(比如在上传大文件时),会报500错误. 只需要设置三个值,就可以解决该问题: 1. client_body_buffer_size: 指定 ...

  5. spring的返回json数据给前端注意事项

    1. 记得加入SpringJSON解析包,否则spring无法将返回的pojo类解析成json数据 maven则加上下面的依赖包 <!-- SpringJSON解析包--> <jac ...

  6. web.xml文件配置模板

    直接贴完整代码,当然,spring的核心控制器依赖包需要通过mean提前配置 <!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.// ...

  7. 第10组 Beta冲刺 总结(组长)

    1.基本情况 组长博客链接:https://www.cnblogs.com/cpandbb/p/14050808.html 答辩总结: ·因为alpha阶段的产品做得偏离了方向,所以beta冲刺大家非 ...

  8. git和命令行 配置proxy请求

    GIT中的操作 设置全局代理 git config --global http.proxy socks5://127.0.0.1:8088 git config --global http.proxy ...

  9. MCU软件最佳实践——独立按键

    1. 引子 在进行mcu驱动和应用开发时,经常会遇到独立按键驱动的开发,独立按键似乎是每一个嵌入式工程师的入门必修课.笔者翻阅了许多书籍(包括上大学时候用的书籍)同时查阅了网上许多网友的博客,无一例外 ...

  10. JUC之线程池基础

    线程池 定义和方法 线程池的工作时控制运行的线程数量,处理过程中将任务放入队列,然后在线程创建后启动这些任务,如果线程数量超过了最大数量,超出数量的线程排队等候,等待其他线程执行完成,再从队列中取出任 ...