TMOOC 1969 开锁
update on 2020.2.28 时隔近日重新想这道题,其实复杂度正确的解法是 可持久化 01 Trie。
考虑对于每一个 \(a[i]\),考虑能将它作为最大值的最大包容区间 \([l, r]\) 在这个里面找一个 \(x\) 使亦或值最大,这显然是可持久化 01 Trie 的标准操作
总复杂度 \(O(N * 32)\)
题目描述
(时间限制:1000ms 内存限制:51200KB)
小明经过千辛万苦,终于来到了 小韩隆的门前。但是小韩隆早有防备,将自己的门锁换成了密码锁。密码锁上有 \(n\) 个数字和一个输入装置。这n个数字是小韩隆刻在锁上的,看来需要解谜了。小明知道小韩隆十分喜欢异或,于是他猜想,这个装置应该是由两个数异或而成。通过小弟们对邻居的询问,小明知道了这个密码是由如下方法构造出的:从$ n $个数字中任选一段数字 \(I\) 到 \(r\),从其中任选一个数$ X \(,将这一段数的最大值与\) x \(异或起来得到y。锁的密码就是所有\) y \(值中的最大值。小明冥思苦想了几个小时,终于发现:因为\) l $、 $r $、 \(x\) 都是他自己选的,所以得到的y值会有很多个。由于小明受到NOIP的打击,十分厌恶“大力出奇迹”,他不想再一个一个试密码。现在他找到了作为小弟的你,想要你告诉他锁的密码是多少。
但是小明没有算到的是,小小明来到了小韩隆家做客,他改变了密码锁的密码。现在密码是这样构造的:从 \(n\) 个数字中任选一段数字 \(I\) 到 \(r\) ,从其中任选一个数 \(X\) ,将这一段数的次大值与 \(x\) 异或起来得到 \(y\) 。锁的密码就是所有 \(y\) 值中的最大值。因为你十分讨厌小明,不想让他大力出这个密码,所以你要算出小小明改完之后,这个锁的密码是多少,方便误导小明。
输入样例
5
9 2 1 4 7
输出样例
14
样例解释
第一个样例\(l\)=1,\(r\)=5,选取的\(x\)为9,密码为7^9=14。
数据范围
对于40%的数据:\(n\)<=5000。
对于100%的数据:1<=\(n\)<=50000,1<=\(a[i]\)<=10^9,保证\(a[i]\)两两不同。
思路
设\([i][j][0]\)为从ij的最大值、$f[i][j][1]$为从ij的次大值。
那么,对于任意i~j,a[i]来说,
- 如果\(a[i]>f[i][j-1][0]\),那么\(f[i][j][1]=f[i][j-1][0]\)、\(f[i][j][0]=a[i]\)(顺位下沿),可以异或的y值为\(a[i]\) xor \(a[i...j-1]\)。
- 否则如果\(a[i]>f[i][j-1][1]\),那么\(f[i][j][1]=a[i]\)(替换次大),可以异或的y值为\(a[i]\) xor \(a[i...j-1]\)。
- 否则,那么\(f[i][j][0]=f[i][j-1][0]\)、\(f[i][j][1]=f[i][j-1][1]\),可以异或的y值为\(f[i][j][1]\) xor \(a[i]\)(剩下的异或已经处理一遍了)。
但是,这道题N的范围是50000,开\(f[50000][50000][2]\)空间肯定会炸。
考虑到第二维度的值只是当前处理的j,可以使用滚动数组降维。
设\(f[i][0]\)为从i(当前的j)的最大值、$f[i][1]$为从i(当前的j)的次大值。既可解决空间不足的问题。
参考代码
水过了。
#include <cstdio>
#include <cmath>
using namespace std;
int n,a[10001],f[10001][2],ans;
int main() {
scanf("%d",&n);
for(int i=1;i<=n;i++)scanf("%d",a+i);
for(int i=2;i<=n;i++){
for(int j=1;j<i;j++){
if(a[i]>f[j][0]){
f[j][1]=f[j][0];
f[j][0]=a[i];
for(int k=j;k<i;k++)ans=ans>(a[k]^a[i])?ans:a[k]^a[i];
}else if(a[i]>f[j][1]){
f[j][1]=a[i];
for(int k=j;k<i;k++)ans=ans>(a[k]^a[i])?ans:a[k]^a[i];
}else{
ans=ans>(f[j][1]^a[i])?ans:(f[j][1]^a[i]);
}
}
}
printf("%d",ans);
}
TMOOC 1969 开锁的更多相关文章
- java模拟开锁
java模拟开锁 service qq:928900200 Introduction to Computer Science II: CSCI142Fall 2014Lab #1Instructor: ...
- 4位开锁<dfs>
题意: 有一个四位密码的锁,每一位是1~9的密码,1跟9相连.并且相邻的连个密码位可以交换.每改变一位耗时1s,给出锁的当前状态和密码,求最少解锁时间. 思路: 用bfs枚举出所有相邻交换的情况,并记 ...
- hihocoder 1075 : 开锁魔法III
描述 一日,崔克茜来到小马镇表演魔法. 其中有一个节目是开锁咒:舞台上有 n 个盒子,每个盒子中有一把钥匙,对于每个盒子而言有且仅有一把钥匙能打开它.初始时,崔克茜将会随机地选择 k 个盒子用魔法将它 ...
- #1075 : 开锁魔法III
描述 一日,崔克茜来到小马镇表演魔法. 其中有一个节目是开锁咒:舞台上有 n 个盒子,每个盒子中有一把钥匙,对于每个盒子而言有且仅有一把钥匙能打开它.初始时,崔克茜将会随机地选择 k 个盒子用魔法将它 ...
- Hiho #1075: 开锁魔法III
Problem Statement 描述 一日,崔克茜来到小马镇表演魔法. 其中有一个节目是开锁咒:舞台上有 n 个盒子,每个盒子中有一把钥匙,对于每个盒子而言有且仅有一把钥匙能打开它.初始时,崔克茜 ...
- 为什么我没有拔出钥匙 ——开锁引发的程序bug解决方案的思考
http://blog.csdn.net/wojiushiwo987/article/details/8851204为什么我没有拔出钥匙 ——开 ...
- HihoCoder 1075 开锁魔法III(概率DP+组合)
描述 一日,崔克茜来到小马镇表演魔法. 其中有一个节目是开锁咒:舞台上有 n 个盒子,每个盒子中有一把钥匙,对于每个盒子而言有且仅有一把钥匙能打开它.初始时,崔克茜将会随机地选择 k 个盒子用魔法将它 ...
- 【树莓派智能门锁】使用脚本控制GPIO来开锁【4】
假定你已经通过此文章或者其他方式完成了树莓派的基本配置 [树莓派]RASPBIAN镜像初始化配置 我们通过VNC View连接到树莓派查看一下~ 1.更新一下基本的设置:更新一下源,把python-d ...
- hrb——开锁魔法I——————【规律】
解题思路:从1到n的倒数之和. #include<stdio.h> #include<string.h> #include<algorithm> using nam ...
随机推荐
- CSS opacity设置不透明度
1.opacity设置不透明度 opacity会将含有这个属性的子类都变成具有opacity属性,可以改变元素.元素内容.字标签的不透明度.而rgba只会改变设置的那个背景颜色的透明度效果 <! ...
- webug第十五关:什么?图片上传不了?
第十五关:什么?图片上传不了? 直接上传php一句话失败,将content type改为图片 成功
- 使用Camtasia来给视频或者图片调色
喜欢摄影和制作视频的朋友可能知道,一张好看的照片或一段精美视频的构成要素很多,取景本身就是很重要的条件,相机的硬件水平也是一个重要因素,接下来的就是后期的编辑和处理了,而在后期处理过程中调色是十分重要 ...
- 如何将各种音频视频素材导入Vegas?
使用vegas制作视频时,我们经常需要将音频和视频素材导入到媒体库中,以此来达到完美的视听结合效果.其实vegas导入素材并不难,因此很多有剪辑经验的朋友完全可以不用看下去了,主要是纯小白自学视频剪辑 ...
- yii2.0 curl的使用
yii2 curl的使用办法 get: use linslin\yii2\curl; public function actionCurl($value =0) { $url = 'http://ya ...
- 多态,向上转型,向下转型,final关键字
多态 概述 多态封装性,继承性之后,面向对象的第三大特性. 定义 多态:是指同一种行为,具有多个不同的表现形式. 生活中,比如跑的动作,猫,狗,大象跑起来的动作都是不一样的,再比如飞的动作 ...
- Mat使用详解
背景 笔记中躺了很久的文章,今天用到Mat时发现之前写的内容还算清晰,分享出来; 如下所举例使用的dump文件是针对之前使用的ignite库溢出时的dump文件:关于ignite的概念此处不再叙述,本 ...
- 知识解析:C语言函数有一些什么?为你呈现最全函数大全
大家双节快乐呀~国庆节过去了一半,大家放了几天假呀?玩的开心吗? 如果假日没有其他安排,不要宅在家虚度光阴哦~看看我的文章或者视频学习一些知识吧~ 今天为大家分享C语言库函数知识. 以下图片以字母 ...
- 2020.11最新JAVA环境安装配置
Windows10下java环境配置 更新:2020年11月25日 电脑环境: windows10 64位 一.下载jdk 首先到Oracle网站下载对应操作系统的jdk安装包. https://ww ...
- Springboot结合Jpa的外键使用
当我们写项目的时候,总有些奇奇怪怪的理由,非让你连表查询,其实最好的就是什么都不连,数据库完全解耦 但我们还是要学习下Jpa怎么根据外键查询 (这里说下Jpa+springboot的感觉,刚开始就感觉 ...