【神奇性质】【P5523】D [yLOI2019] 珍珠
D [yLOI2019] 珍珠
Description
给定一个 deque,要求支持 push_back 和 push_front 操作,并且查询前缀与非和以及后缀与非和。
deque中只会有 \(0\) 或 \(1\),一共有 \(n\) 次操作,其中有 \(m\) 次操作给定,剩下的操作随机。
Limitations

Solution
这是一道通过输入格式来防AK的题目
下面的做法只考虑前缀与非和,因为后缀的做法与前缀完全相同。
子任务 \(0\):
没有操作,输出四个 \(0\) 即可。期望得分 \(5~pts\)
子任务 \(1\):
暴力模拟,每次从前面插入的时候后面的元素暴力移位,暴力查询与非和即可。时间复杂度 \(O(n^2)\),期望得分 \(15~pts\)
子任务 \(2\):
考虑用线段树来维护每个区间的与非和,但是这样产生了一个问题,两个区间的与非和是无法合并的,因为与非运算没有交换律和结合律。
但是我们注意到事实上对于某个区间,序列的首部到区间左端点之前所有元素的与非和只可能是 \(0\) 或 \(1\),因此线段树每个节点维护两个信息:当该区间之前所有元素的与非和是 \(0\) 时与非上该区间的值,以及当该区间之前元素与非和是 \(1\) 时与非上该区间的值,然后即可 \(O(1)\) 转移。
时间复杂度 \(O(n \log n)\),期望得分 \(15 ~pts\)
子任务 \(3\):
插入的元素全部是 \(1\)。
考虑一堆连续 \(1\) 的前缀与非和序列,一定形如 \(101010101\dots\)
证明上,考虑第一个位置一定是 \(1\),然后 \(1~\text{nand}~1~=~0\) ,\(0~\text{nand}~1~=~1\),因此序列中 \(0\) 和 \(1\) 一定是循环出现的。
因此一个询问的答案一定是 \(y~\&~1\)。时间复杂度 \(O(n)\),期望得分 \(10~pts\)
子任务 \(4\):
插入的元素全部是 \(0\)。
考虑一堆 \(0\) 的前缀与非和序列,一定形如 \(011111111111 \dots\)
用与子任务 \(3\) 类似的办法即可解决。时间复杂度 \(O(n)\),期望得分 \(10~pts\)
子任务 \(5\):
考虑一个显而易见的事实,\(0\) 与非任何数都得 \(1\)。
因此考虑一次查询如果与非和的最后一项是 \(0\),则直接返回 \(1\) 即可。
同时对于最后一项是 \(1\) 的操作,只需要看这一项向前一共有连续的几个 \(1\),由于前面那一项是 \(0\),所以一段 \(011111\) 的序列的与非和一定是 \(1010101010\dots\),而与 \(0\) 前面的项完全无关。
当然需要特判查询的 \(0\) 是序列第一个元素,以及查询的 \(1\) 前面没有 \(0\) 的情况。
那么问题就变成了对于每个位置维护它前面第一个 \(0\) 的位置。
由于 \(m = 0\) ,序列中的元素是完全随机的,因此连续 \(0/1\) 段的长度期望都是常数级的,因此暴力找即可,期望时间复杂度 \(O(n)\),期望得分 \(15~pts\)
子任务 \(6\):
考虑在序列不随机时怎么对每个数维护它前面第一个 \(0\) 的位置。
事实上,在每插入一个 \(0\) 时,都暴力修改这个 \(0\) 的有元素的一侧的连续 \(1\) 的信息即可。
例如,在序列左侧插入一个 \(0\),则暴力修改 \(0\) 右侧连续 \(1\) 的左侧最近的 \(0\) 的位置为该位置即可。在序列右侧插入同理。
考虑时间复杂度:每个为 \(1\) 的元素都只会在左侧最近和右侧最近的 \(0\) 插入的时候被修改信息,因此每个元素都只会被修改 \(O(1)\) 次信息,即每次均摊修改 \(O(1)\) 个信息,总的修改次数为 \(O(n)\),因此总时间复杂度 \(O(n)\),期望得分 \(30~pts\)。
appreciation
感谢@Burnside 神仙帮助进行题解的校对工作
【神奇性质】【P5523】D [yLOI2019] 珍珠的更多相关文章
- WPF中的常用布局 栈的实现 一个关于素数的神奇性质 C# defualt关键字默认值用法 接口通俗理解 C# Json序列化和反序列化 ASP.NET CORE系列【五】webapi整理以及RESTful风格化
WPF中的常用布局 一 写在开头1.1 写在开头微软是一家伟大的公司.评价一门技术的好坏得看具体的需求,没有哪门技术是面面俱到地好,应该抛弃对微软和微软的技术的偏见. 1.2 本文内容本文主要内容 ...
- 一些Fibonacci数列的神奇性质【数学】
递推式: \(f_i=1 (1\leq i\leq 2)\) \(f_i=f_{i-1}+f_{i-2}(i>2)\) 一些性质 \(\sum_{i=1}^n f_i=f_{n+2}-1\) \ ...
- LCT专题练习
[bzoj2049]洞穴勘测 http://www.cnblogs.com/Sdchr/p/6188628.html 小结 (1)LCT可以方便维护树的连通性,但是图的连通性的维护貌似很麻烦. [bz ...
- 【ContestHunter】【弱省胡策】【Round3】(C)
容斥原理+Fib Orz HE的神犇们 蒟蒻只能改出来第三题……实在太弱 官方题解:http://pan.baidu.com/s/1o6MdtQq fib的神奇性质……还有解密a[i]的过程……这里就 ...
- 第八届郑州轻工业学院ACM(程序设计大赛)校内预选赛
郑州轻工业学院有一个大赛,把几个有趣的题目分享一下.下面是题目连接,喜欢了就点点... 斗破苍穹 礼上往来 统计人数 神の数 炉石传说 Mathematics and Geometry 马拉松后记 斗 ...
- bzoj4817 [Sdoi2017]树点涂色
Description Bob有一棵n个点的有根树,其中1号点是根节点.Bob在每个点上涂了颜色,并且每个点上的颜色不同.定义一条路 径的权值是:这条路径上的点(包括起点和终点)共有多少种不同的颜色. ...
- 海量数据挖掘MMDS week3:社交网络之社区检测:高级技巧
http://blog.csdn.net/pipisorry/article/details/49052255 海量数据挖掘Mining Massive Datasets(MMDs) -Jure Le ...
- 高斯消元(Gauss消元)
众所周知,高斯消元可以用来求n元一次方程组的,主要思想就是把一个n*(n+1)的矩阵的对角线消成1,除了第n+1列(用来存放b的)的其他全部元素消成0,是不是听起来有点不可思议??! NO NO NO ...
- JXOI2018简要题解
JXOI2018简要题解 T1 排序问题 题意 九条可怜是一个热爱思考的女孩子. 九条可怜最近正在研究各种排序的性质,她发现了一种很有趣的排序方法: Gobo sort ! Gobo sort 的算法 ...
随机推荐
- vertica 中位数函数 MEDIAN 的使用
中位数函数:MEDIAN 使用表达式:MEDIAN ( expression ) OVER ( [ window‑partition‑clause ] ) 准备测试数据: ), name ), sal ...
- 通过IP获取MAC地址例子(内核层)
博客地址:http://home.cnblogs.com/u/zengjianrong/ 在内核处理此流程,反而更加简单些,代码如下: #include <net/arp.h> #incl ...
- 集合类源码(六)Map(HashMap, Hashtable, LinkedHashMap, WeakHashMap)
HashMap 内部结构 内部是一个Node数组,每个Node都是链表的头,当链表的大小达到8之后链表转变成红黑树. put操作 final V putVal(int hash, K key, V v ...
- IDEA rider 管道模式 经典模式(2)
1.这里设置为Classic,并打开applicationhost.config将对应应用的 Clr4IntegratedAppPool全部替换为 Clr4ClassicAppPool 2.Confi ...
- 四种软件开发模式:tdd、bdd、atdd和ddd的概念
看一些文章会看到TDD开发模式,搜索后发现有主流四种软件开发模式,这里对它们的概念做下笔记. TDD:测试驱动开发(Test-Driven Development) 测试驱动开发是敏捷开发中的一项核心 ...
- 缓存雪崩、穿透如何解决,如何确保Redis只缓存热点数据?
缓存雪崩如何解决? 缓存穿透如何解决? 如何确保Redis缓存的都是热点数据? 如何更新缓存数据? 如何处理请求倾斜? 实际业务场景下,如何选择缓存数据结构 缓存雪崩 缓存雪崩简单说就是所有请求都从缓 ...
- dotnet core 之 gRPC
dotnet core gRPC 原文在本人公众号中,欢迎关注我,时不时的会分享一些心得 HTTP和RPC是现代微服务架构中很常用的数据传输方式,两者有很多相似之处,但是又有很大的不同.HTTP是一种 ...
- python 绘图与可视化 Graphviz 二叉树 、 error: Microsoft Visual C++ 14.0 is required
需要对二叉树的构建过程进行可视化,发现了这个Graphviz软件,他对描绘数据间的关系十分擅长. 下载链接:https://graphviz.gitlab.io/_pages/Download/Dow ...
- Java集合Map基本方法
jdk1.7 api中的方法摘要: 参考java集合大全图:https://www.cnblogs.com/xkzhangsanx/p/10889114.html Map为所有Map子类的接口.
- html书写行内元素时-tab和换行会在行内元素间引入间距
目录 html文本中的控制字符会被解析为文本节点 书写行内元素时,换行符LF与水平制表符HT会引入莫名的元素间间隔 其他控制字符是否会引入间距的验证 html文本中的控制字符会被解析为文本节点 举例: ...