这套题还是有点质量的吧 ……

题目链接

A. XORinacci

傻叉签到题,因为异或的性质所以这个序列的循环节长度只有 \(3\) ……

查看代码

B. Uniqueness

因为序列长度乃至数的种类都不超过 \(2000\),考虑先把序列离散化。

题意让我们求一个最短的区间满足如下性质,对于每一种数,其在此区间出现次数不小于在原序列中的出现次数减 \(1\)。

可以先前缀和求一下对于每种数,当前位置及之前的出现次数,和至少一共需要删掉多少个这种数,即在原序列中的出现次数减 \(1\),方便以后的计算。

然后双指针确定一个这个区间即可,因为支持$ O(n^2)$ 的算法,所以 \(for\) 每一种数暴力 \(Check\)。

查看代码

C. Magic Grid

结论题,看到 \(n\) 是 \(4\) 的倍数就自然想到将网格拆成若干个 \(4 * 4\) 的网格来做,每一部分网格依然满足题意的性质,并且拼起来也使大网格满足题意性质。

结果发现 \(2 * 2\) 的网格即可满足性质…… 对于每一组连续的 \(4\) 个数,存在一种构造方法满足上述性质。

不明白就看代码吧,挺简单的。

查看代码

D. Restore Permutation

一道傻叉线段树因为写错递归的函数名调了半个多小时…… 属实降智了……

一开始读错题,看成是 \(s_i\) 表示 \(i\) 之前满足 \(p_j < p_i\) 的数的个数,那这道题目的套路就很常见,从后向前推,最后一个数就是当前未选的数中的第 \(s_i + 1\) 个数。

而正确的题意可谓从这上面发展而来,\(s_i\) 表示 \(i\) 之前满足 \(p_j < p_i\) 的数值之和。相当于把上述题意中,一个数的贡献从 \(1\) 改为了其数值而已。这样,用线段树维护前缀和,每次在上面二分查应该到哪个位置,即当前的数,然后选了的数就单点修改为 \(0\) 来删除对前缀和的贡献。

至于一些细节,思路清晰的话试一下就出来了。

查看代码

E. Let Them Slide

没来得及写,不过真的没想到只做 \(4\) 题也上分了……

容易发现每一行都是独立的,对每一列,我们只需要把每一行能对这个位置做的最大贡献加起来就好了,所以对每一行单独处理。

设 \(len\) 为当前行的序列长度,当 \(w > 2 * len\) 时,显然区间 \([len + 1,\ w - len]\) 是可以取到每一个数,包括空位置(贡献为 \(0\))的,对这一段区间可以直接加上 \(max(max\_num,\ 0)\),\(max\_num\) 为序列中最大值。

现在处理区间 \([1,\ len]\) 和 \([w - len + 1,\ w]\),画图总结,对于前者中的每一个位置 \(j\),能取到的序列中的数为 \([max(0,\ j - w + len),\ j]\),对于后者,为 \([j - w + len,\ min(j,\ len + 1)]\),那么贡献就是这段区间中的区间最大值。

注意这两段区间如果存在重叠部分不要重叠区间计两次贡献,至于区间最大值,用 \(st\) 表处理即可,至于贡献的统计可以随便用数据结构做。

查看代码

F. Bits And Pieces

思路很巧妙,完全没思路…… 本没脑子选手的水平看来也就半斤八两,到此为止了……

考虑按位与的操作只会让二进制中的 1 变少,因此值域不会变大,可以对每一个数,统计其可以被与出哪些数,并让此数 \(x\) 对 \(cnt[x]\) 做出 \(1\) 的贡献。

巧妙之处在于,如果有两个数都可以通过与运算得到 \(x\),那让这两个数做按位与,就可以与出一个二进制上只会比 \(x\) 多出 \(1\) 而不会少的数,即 \(x\) 是其二进制的子集。换句话说,如果用它做或运算,那么至少能做出 \(x\) 所做的贡献。

这样,我们只想要知道有哪些数可以被序列中的两个数做与运算得到。

可以 \(Dfs\) 爆枚二进制子集来统计其可以被与出哪些数,这样每个数至多是 \(O(2^{20})\) 的。但是如果一个数已经处理过两次了,也就是说它及其它二进制的子集已经都能被某两个数来与出两次了,那么已经达到了我们的目的,就无需再处理了,所以总渐进时间复杂度是 \(O(n)\) 的。

我们要求的是当前数与后面某两个数按位或得到的最大值,就可以从上面 \(cnt[]\) 大于 \(2\) 的数中找,从高位到低位贪心地让 \(0\) 变成 \(1\),这里可以结合代码理解。

查看代码

Manthan Codefest 19 题解的更多相关文章

  1. Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)-D. Restore Permutation-构造+树状数组

    Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)-D. Restore Permutation-构造+树状数组 [Pro ...

  2. Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)-C. Magic Grid-构造

    Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)-C. Magic Grid-构造 [Problem Descripti ...

  3. Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)-E. Let Them Slide-思维+数据结构

    Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)-E. Let Them Slide-思维+数据结构 [Problem ...

  4. Manthan, Codefest 19(Div. 1 + Div. 2)

    传送门 A. XORinacci 签到. Code /* * Author: heyuhhh * Created Time: 2020/2/26 9:26:33 */ #include <ios ...

  5. Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2) F. Bits And Pieces sosdp

    F. Bits And Pieces 题面 You are given an array

  6. Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2) G. Polygons 数论

    G. Polygons Description You are given two integers

  7. Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2) (1208F,1208G,1208H)

    1208 F 大意:  给定序列$a$, 求$\text{$a_i$|$a_j$&$a_k$}(i<j<k)$的最大值 枚举$i$, 从高位到低位贪心, 那么问题就转化为给定$x$ ...

  8. Manthan, Codefest 19

    目录 Contest Info Solutions A. XORinacci B. Uniqueness C. Magic Grid D. Restore Permutation E. Let The ...

  9. RMQ+差分处理(Let Them Slide)Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2)

    题意:https://codeforc.es/contest/1208/problem/E 现有n行w列的墙,每行有一排连续方块,一排方块可以左右连续滑动,且每个方块都有一个价值,第i 列的价值定义为 ...

随机推荐

  1. 解惑:如何使得寝室的电脑和实验室的电脑远程相互访问(Linux和Windows)

    解惑:如何使得寝室的电脑和实验室的电脑远程相互访问 一.前言 自从接触计算机网络之后就一直想着把实验室的电脑和自己寝室的电脑远程连接起来,结果总是郁郁不能成功,网上这样的教材也少的可怜,于是总是搁置下 ...

  2. ubuntu / zsh shell / oh-my-zsh / 常用插件

    记录一下 zsh 的下载与配置,省得每次重装系统都要上网到处查. 安装 zsh shell sudo apt install zsh 切换 shell chsh -s /bin/zsh 安装 oh-m ...

  3. set -x 与 set +x

    set -x 与 set +x 在liunx脚本中可用set -x就可有详细的日志输出.免的老是要echo了 下面的网上搜来的用法. 用于脚本调试.set是把它下面的命令打印到屏幕set -x 是开启 ...

  4. SourceTree 版本跳过bitbucket注册方法

    1.安装sourcetree时 需要选择 bitbucket账号,这个令人头疼 当然肯定有办法来跳过这一步 2.关闭当前安装界面 进入   C:\Users\Administrator\AppData ...

  5. jdk-8u151-nb-8_2-windows-x64软件安装教程及环境配置

    1.双击jdk-8u151-windows-x64.exe文件 2.进入安装向导 3.配置环境变量 (1)计算机→属性→高级系统设置→高级→环境变量 (2)系统变量→新建 JAVA_HOME 变量 . ...

  6. Kubernetes 弹性伸缩全场景解析(三) - HPA 实践手册

    在上一篇文章中,给大家介绍和剖析了 HPA 的实现原理以及演进的思路与历程.本文我们将会为大家讲解如何使用 HPA 以及一些需要注意的细节. autoscaling/v1 实践 v1 的模板可能是大家 ...

  7. 用ASP.NET创建数据库

    小白的第一次使用: 程序员写程序,就好比一个物品的慢慢诞生,我们今天的这个例子就可以想象成一个物品慢慢的在编译的过程中,让我们所看到 一.创建我们所测试的项目 1.创建一个简单的带有模型层(Model ...

  8. C# 多线程处理List数据

    代码思路 将要处理的数据放到ConcurrentQueue中,然后开启多个线程去处理数据,处理完成后,再到队列中获取下一个待处理数据. ConcurrentQueue 表示线程安全的先进先出 (FIF ...

  9. Postman 调试请求Asp.Net Core3.0 WebApi几种常见的Get/Post/Put/Delete请求

    这里就直接截图了,如下(很简单的操作): 1:Get几种请求 2:Post 3:Put 4:Delete  最后,虽然简单,代码还是给放一下(这里只是抛砖引玉的作用,自己可以根据自身的业务需要来做进一 ...

  10. BCP 运行错误

    记录下使用bcp导出csv文件时的错误: [Microsoft][ODBC SQL Server Driver][SQL Server]对象名 '***'无效问题的解决方案器 我们要对student数 ...