链接:https://ac.nowcoder.com/acm/contest/317/C
来源:牛客网

小a正在玩一款星际探索游戏,小a需要驾驶着飞船从1号星球出发前往n号星球。其中每个星球有一个能量指数p。星球i能到达星球j当且仅当pi>pj。
同时小a的飞船还有一个耐久度t,初始时为1号点的能量指数,若小a前往星球j,那么飞船的耐久度会变为t⊕pj(即t异或pj,关于其定义请自行百度)
小a想知道到达n号星球时耐久度最大为多少

注意:对于每个位置来说,从它出发可以到达的位置仅与两者的p有关,与下标无关

输入描述:

第一行一个整数n,表示星球数
接下来一行有n个整数,第i个整数表示pi

输出描述:

一个整数表示到达n号星球时最大的耐久度
若不能到达n号星球或到达时的最大耐久度为0则输出−1
示例1

输入

复制

3
457 456 23

输出

复制

478

说明

小a有两种方法到达33号星球
第一种:1→2→31→2→3,最终耐久度为457⊕456⊕23=22457⊕456⊕23=22
第二种:1→31→3,最终耐久度为457⊕23=478457⊕23=478
示例2

输入

复制

4
2 4 4 2

输出

复制

-1
示例3

输入

复制

5
234 233 123 2333 23

输出

复制

253

备注:

1⩽n,∀pi⩽3000

这题很明显线性基,但是一开始做的时候没有看到 pi 必须大于 pj 这条限制条件 就直接打了,打完发现样例不过,自己也看不懂样例。
重新读了一遍题才发现那个条件,果然电子竞技不需要视力。
只需要把P0作为最大值 Pn-1作为最小值,处理出来新的数组,然后再线性基最大值就行了。 也可以用暴力dp 。
处理出来新的数组,并排序。将本题的移动方式更改为:
从第一个点走到最后一个点,可以自由选择是否在当前点异或(第一个点和最后一个点除外)
dp[i][j] 表示 走到第i个点 并 进行完是否在i处异或的抉择之后,值能否为 j
此代码为线性基的代码。
#include<cstdio>
#include<algorithm>
#include<cstring>
using namespace std;
int arr[];
int stu[];
int p[];
int main(){
int n;
int cnt=;
int ans;
scanf("%d",&n);
for(int i=;i<n;i++){
scanf("%d",&arr[i]);
}
if(arr[]<=arr[n-]){
puts("-1");
return ;
}
ans = arr[]^arr[n-];
for(int i=;i<n-;i++){
if(arr[n-] < arr[i] && arr[i] < arr[])
stu[cnt++] = arr[i];
}
memset(p,,sizeof(p));
for(int i=;i<cnt;i++){
for(int j=;j>=;j--){
if(stu[i]>>j&){
if(p[j]){
stu[i] ^= p[j];
}else {
p[j] = stu[i];
break;
}
}
}
}
for(int i=;i<;i++){
for(int j=i+;j<;j++){
if(p[j]>>i&)p[j]^=p[i];
}
}
for(int i=;i<;i++){
if(ans < (ans ^ p[i]))
ans ^= p[i];
}
printf("%d\n",ans);
return ;
}

此为dp代码。

#include   <cstdio>
#include <cstring>
#include<algorithm>
using namespace std; const int maxn = (<<);
int arr[];
int stu[];
bool dp[][maxn];
bool cmp(int a,int b){
return a > b;
}
int main(){
int n;
int cnt=;
scanf("%d",&n);
for(int i=;i<n;i++)
scanf("%d",&arr[i]);
if(arr[]<=arr[n-]){
puts("-1");
return ;
}
stu[cnt++] = arr[];
stu[cnt++] = arr[n-];
for(int i=;i<n-;i++){//处理出新数组
if(arr[n-] < arr[i] && arr[i] < arr[])
stu[cnt++] = arr[i];
} sort(stu,stu+cnt,cmp);
dp[][stu[]]=;
for(int i=;i<cnt;i++){
if(i==cnt-){//最后一个点
for(int j=maxn-;j;j--){
// 从大到小 遍历所有可能的 j 值
dp[i][j] |= dp[i-][j ^ stu[i]];
if(dp[i][j]){printf("%d\n",j);return ;}
}
}else if(stu[i]==stu[i-]){
//因为和前一个点的值一样,所以dp的结果也一样
memcpy(dp[i],dp[i-],sizeof(dp[i]));
}else{
for(int j=;j<maxn;j++){
// 在i点的 j 值可以由i-1处用(j^stu[i])这个值来异或stu[i]得到
// 也可以由 i-1处的j值不在i处异或stu[i]得到
dp[i][j] |= dp[i-][j^stu[i]] | dp[i-][j];
}
}
}
puts("-1");
return ;
}

牛客 小a与星际探索的更多相关文章

  1. 牛客 小a与星际探索 bfs

    链接:https://ac.nowcoder.com/acm/contest/317/C?&headNav=acm来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ ...

  2. 小a与星际探索

    链接:https://ac.nowcoder.com/acm/contest/317/C来源:牛客网 小a正在玩一款星际探索游戏,小a需要驾驶着飞船从11号星球出发前往nn号星球.其中每个星球有一个能 ...

  3. 小a与星际探索---DP

    题目描述 小a正在玩一款星际探索游戏,小a需要驾驶着飞船从11号星球出发前往nn号星球.其中每个星球有一个能量指数pp.星球ii能到达星球jj当且仅当pi>pjpi>pj.同时小a的飞船还 ...

  4. 牛客-小a的旅行计划 + 数学推导

    小a的旅行计划 题意: 小a终于放假了,它想在假期中去一些地方游玩,现在有N个景点,编号为,同时小b也想出去游玩.由于一些特殊♂原因,他们的旅行计划必须满足一些条件 首先,他们可以从这N个景点中任意选 ...

  5. 牛客-小y的盒子

    题目传送门 -------------------稍加观察就会发现,4n - 1就是题目要的答案.至于为什么,看官方的题解.不过这个n非常的大,用正常快速幂解决不了.这道题我学到的就是解决幂非常大的情 ...

  6. 牛客-小w的a=b问题

    题目传送门 sol1:老实做,预处理出所有2到1e5的素数,对所有数进行分解质因数,然后对比因子个数.感觉有点卡常,用了快读然后多次优化之后才过的,map也用上了. 素数筛,快速分解质因数 #incl ...

  7. 牛客小白月赛13 小A买彩票 (记忆化搜索)

    链接:https://ac.nowcoder.com/acm/contest/549/C来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 262144K,其他语言52428 ...

  8. 牛客小白月赛13-J小A的数学题 (莫比乌斯反演)

    链接:https://ac.nowcoder.com/acm/contest/549/J来源:牛客网 题目描述 小A最近开始研究数论题了,这一次他随手写出来一个式子,∑ni=1∑mj=1gcd(i,j ...

  9. 牛客OI周赛7-提高组 A 小睿睿的等式

    链接:https://ac.nowcoder.com/acm/contest/371/A来源:牛客网 小睿睿在游戏开始时有n根火柴棒,他想知道能摆成形如“A+B=n”的等式且使用的火柴棒数也恰好等于n ...

随机推荐

  1. EF6 AddOrUpdate之后,数据没有改变而是新增了一条数据解决办法

    EF:修改不是查询出来的对象dbContext.Web_User.AddOrUpdate(user);dbContext.SaveChanges(); 上面的写法有时候可能不起作用,而且把这条数据重复 ...

  2. CSharp调用C++编写的DLL的方法

    自己比较懒,有的时候想写点东西,但由于文笔不行.技术不行也就没有怎么写.经常是用到什么.学习什么的时候,简单写点,权当是个学习笔记.上博客的次数也很少,有人给我留言也是没有怎么及时的回复,深感抱歉! ...

  3. Java 的标识接口作用

    原文地址:标识接口 作用作者:feisong 时间:2019-01-2315:49:35 标识接口是没有任何方法和属性的接口.标识接口不对实现它的类有任何语义上的要求,它仅仅表明实现它的类属于一个特定 ...

  4. Plugin was not installed: Cannot download 'https://plugins.jetbrains.com/pluginManager''

    在Android studio中安装插件的时候,提示了类似这种的错误,解决这个问题有以下几步 1.打开Configure->Settings 2.System Settings->Upda ...

  5. ECSHOP和SHOPEX快递单号查询韵达插件V8.6专版

    发布ECSHOP说明: ECSHOP快递物流单号查询插件特色 本ECSHOP快递物流单号跟踪插件提供国内外近2000家快递物流订单单号查询服务例如申通快递.顺丰快递.圆通快递.EMS快递.汇通快递.宅 ...

  6. connect() to unix:/var/run/php-fpm.sock failed (11: Resource temporarily unavailable)

    nginx + php做服务,在高并发的时候会出现一些错误  connect() to unix:/var/run/php-fpm.sock failed (11: Resource temporar ...

  7. 使用SQLite删除Mac OS X 中launchpad里的快捷方式

    一般情况下,从App Store安装的应用程序,如果应用删除,那么launchpad里对应的图标会一起删除了. 而对于不是通过App Store安装的应用程序,删除应用程序,Launchpad中很可能 ...

  8. Learning Experience of Big Data:The First Day-Try to set up a network connection on my virtural machine

    After we install our virtual machine,the first thing we should do is to set up a network connection ...

  9. Vijos 纸牌

    题目网址 https://vijos.org/d/Randle/p/5a0011e1d3d8a10a532d6d71 题目描述 在桌面上放着n张纸牌,每张纸牌有两面,每面都写着一个非负整数.你的邪王真 ...

  10. Python3 使用基本循环实现多级目录(思路)

    一.多级目录设计: 1. 通过循环的方式显示菜单和进入菜单 2. 设置标志位以提供回退上一层菜单 2. 设置标志位以提供退出程序 二.注意要点: 1. 菜单样式,层次关系不要弄混乱 2. 当输入错误时 ...