Manthan, Codefest 19
目录
Contest Info
Solved | A | B | C | D | E | F | G | H |
---|---|---|---|---|---|---|---|---|
6/8 | O | O | Ø | O | O | Ø | - | - |
- O 在比赛中通过
- Ø 赛后通过
- ! 尝试了但是失败了
- - 没有尝试
Solutions
A. XORinacci
题意:
\(f(0) = 1, f(1) = b, f(n) = f(n - 1) \oplus f(n - 2)\),求\(f(n)\)。
思路:
循环节为\(3\)。
B. Uniqueness
题意:
给出一个序列\(a_i\),可以删去连续的一段,使得剩下的数是互不相同的。
求删除的那一段的最小长度。
思路:
枚举左端点,那么一个右端点可行,当且仅当左端点左边的数是互不相同的,右端点右边的数是互不相同的,并且右端点右边的数中没有左端点左边的数。
- 左端点左边的数是互不相同的,右端点右边的数是互不相同的
- 这两个条件可以\(O(n)\)预处理。
- 右端点右边的数中没有左端点左边的数。
- 这个条件可以维护左端点的数中最后一次出现的位置的最大值,那么右端点比这个最大值还大即可。
C. Magic Grid
题意:
构造一个\(n \cdot n\)的矩阵,里面的数为\([0, n^2 - 1]\)的一个排列。
要求每一行以及每一列的异或和相同。
\(n = 4k\).
思路:
对于\(4\)的情况这样构造:
0 1 2 3
4 5 6 7
8 9 10 11
12 13 14 15
发现每一行每一列都是\(0\)。
那么对于\(n = 4k\)的情况,直接划分成若干个\(4 \cdot 4\)的小矩形,这样仿照的画葫芦即可。
D. Restore Permutation
题意:
有一个排列\(p_i\),现在告诉你\(s_i\):
\[
\begin{eqnarray*}
s_i = \sum\limits_{p_j < p_i} p_j
\end{eqnarray*}
\]
要求还原出\(p_i\)。
思路:
显然一个合法的\(s_i\)的序列唯一对应一个\(p_i\)序列,那么我们从最后一个数考虑。
假设最后一个数为\(p_n\),那么\(s_n = p_n(p_n - 1) / 2\)。
其实本质就是小于\(p_n\)的数都在它前面,他们的和构成了\(s_n\)。
那么确定了最后一个数,那么依次倒着确定\(s_{n - 1}, s_{n - 2}, \cdots\)。
用线段树维护还有哪些数没有出现,以及他们的和。
对于每个\(s_i\),在线段树上二分即可。
E. Let Them Slide
题意:
有一个\(n \cdot w\)的矩形,每一行有若干个数,并且每一行的数是可以整体移动的,像这样:
那么现在询问,对于每一列,下面每一行的数如何移动,使得该列的数的和最大,如果没有数那么就是\(0\)。
每一列的询问独立。
思路:
每一行考虑,考虑这一行的哪些数会对哪些列产生贡献。
显然这个每个数产生贡献的范围是连续的,那么用栈贪心维护一下范围即可。
F. Bits And Pieces
题意:
给出一个序列\(a_i\),询问\(a_i \;|\; (a_j \& a_k)\)这个式子的最大值,其中\(i < j < k\)
思路:
考虑固定\(a_i\),然后我们只需要关心\(a_i\)那些二进制位上为\(0\)的位,从高位到低位确定。
比如说对于第\(x\)位,那么我们相当于固定了一个前缀,去找\(i < j < k\)是否存在一个\(a_j\)以及一个\(a_k\),它们都有这样的前缀。
那么直接枚举子集标记前缀即可。 但是这样复杂度不对。
我们可以倒着来,因为我们发现对于一个\((j, k)\),那么肯定希望\(j, k\)越大越好,那么倒着标记即可,这样标记过了肯定不用再标记了,因为被标记过说明下标肯定大于等于当前的下标。
但是要注意下标等于的情况
Manthan, Codefest 19的更多相关文章
- 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 ...
- 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 ...
- 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 ...
- Manthan, Codefest 19(Div. 1 + Div. 2)
传送门 A. XORinacci 签到. Code /* * Author: heyuhhh * Created Time: 2020/2/26 9:26:33 */ #include <ios ...
- 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
- Manthan, Codefest 19 (open for everyone, rated, Div. 1 + Div. 2) G. Polygons 数论
G. Polygons Description You are given two integers
- Manthan Codefest 19 题解
这套题还是有点质量的吧 -- 题目链接 A. XORinacci 傻叉签到题,因为异或的性质所以这个序列的循环节长度只有 \(3\) -- 查看代码 B. Uniqueness 因为序列长度乃至数的种 ...
- 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$ ...
- 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 列的价值定义为 ...
随机推荐
- 将图片画到canvas 上的几种方法(转)
转自:https://blog.csdn.net/qq_15009739/article/details/82809525
- MySQL 索引机制
MySQL 原理篇 MySQL 索引机制 MySQL 体系结构及存储引擎 MySQL 语句执行过程详解 MySQL 执行计划详解 MySQL InnoDB 缓冲池 MySQL InnoDB 事务 My ...
- C#导入Excel表格功能aspx.cs(代码)
using System; using System.Data; using System.Configuration; using System.Collections; using System. ...
- Jlink调试S5PV210
安装CDT C/C++ Development Toolkit,使eclipse可以开发C/C++项目 Help–>Install New Software中输入:http://download ...
- 修改docker容器端口映射的方法
大家都知道docker run可以指定端口映射,但是容器一旦生成,就没有一个命令可以直接修改.通常间接的办法是,保存镜像,再创建一个新的容器,在创建时指定新的端口映射. 有没有办法不保存镜像而直接修改 ...
- redis入门初学知识
一. Redis 介绍 Remote Dictionary Server(Redis)是一个开源的使用 ANSI C 语言编写.支持网络.可基于内存亦可持久化的日志型.Key-Value 数据库,并提 ...
- 记录java+testng运行selenium(四)--- 结构说明
一图:主要是driver文件所在目录,及ini配置文件所在位置. 这两个文件一般我是放在其它目录下,不跟随项目所在目录 二图:用例操作类及用例执行类所在位置. 下图中有接口代码及功能代码组成,之前的文 ...
- 基于fastai的分类网络
classify.fastai Classifier based on fastai 欢迎访问:https://github.com/pprp/classify.fastai/ 字符识别分类器-基于f ...
- orm多表的创建和基于对象的查询
创建模型 实例:我们来假定下面这些概念,字段和关系 作者模型:一个作者有姓名和年龄. 作者详细模型:把作者的详情放到详情表,包含生日,手机号,家庭住址等信息.作者详情模型和作者模型之间是一对一的关系( ...
- attr方法笔记(反射)
attr方法笔记 attr中用到了四个内置面向对象方法(__getattr__,__setattr__,__hasattr__,__delattr__),这称为反射,由于python中一切皆对象,反射 ...