HDU5715 XOR 游戏 二分+字典树+dp
当时Astar复赛的时候只做出1题,赛后补题(很长时间后才补,懒真是要命),发现这是第二简单的
分析:
这个题,可以每次二分区间的最小异或和
进行check的时候用dp进行判断,dp[i][j]代表前i个元素分成j个区间,j是最后一个区间的最后一个元素
如果dp[i][j]为真,表明每个区间长度大于L,异或和大于mid
否则为假
返回dp[n][m]就好
复杂度度 O(30^2*nm)
吐槽:和异或相关的题总是和字典树贪心有关,又是一道,铭记铭记
#include <stdio.h>
#include <algorithm>
#include <string.h>
using namespace std;
const int N = 1e4+;
typedef long long LL;
int n,m,l,T,cas,tot;
int a[N];
struct Node{
int sum,nex[];
}p[N**];
int newnode(){
++tot;
p[tot].sum=;p[tot].nex[]=p[tot].nex[]=-;
return tot;
}
int root[];
void add(int pos,int x){
int now=root[pos],cur;
++p[now].sum;
for(int i=;i>=;--i){
if(x&(<<i))cur=;
else cur=;
if(p[now].nex[cur]==-)
p[now].nex[cur]=newnode();
now=p[now].nex[cur];
++p[now].sum;
}
}
void del(int pos,int x){
int now=root[pos],cur;
--p[now].sum;
for(int i=;i>=;--i){
if(x&(<<i))cur=;
else cur=;
now=p[now].nex[cur];
--p[now].sum;
}
}
int query(int pos,int x){
int now=root[pos],ret=,cur;
if(p[now].sum==)return ;
for(int i=;i>=;--i){
if(x&(<<i))cur=;
else cur=;
if(p[now].nex[cur^]!=-&&p[p[now].nex[cur^]].sum!=){
ret+=(<<i);
now=p[now].nex[cur^];
}
else now=p[now].nex[cur];
}
return ret;
}
bool dp[N][];
bool check(int mid){
tot=;
for(int i=;i<m;++i)
root[i]=newnode();
for(int i=;i<=n;++i)
for(int j=;j<=m;++j)dp[i][j]=false;
dp[][]=true;add(,);
for(int i=;i<=n;++i){
if(i-l->=){
for(int j=;j<=m;++j)
if(dp[i-l-][j])del(j,a[i-l-]);
}
for(int j=;j<=m;++j){
int tmp=query(j-,a[i]);
if(tmp>=mid)add(j,a[i]),dp[i][j]=true;
}
} return dp[n][m];
}
int main(){
scanf("%d",&T);
while(T--){
scanf("%d%d%d",&n,&m,&l);
for(int i=;i<=n;++i)
scanf("%d",&a[i]),a[i]^=a[i-];
int l=,r=1e9+,ret;
while(l<=r){
int mid=(l+r)>>;
if(check(mid))l=mid+,ret=mid;
else r=mid-;
}
printf("Case #%d:\n%d\n",++cas,ret);
}
return ;
}
HDU5715 XOR 游戏 二分+字典树+dp的更多相关文章
- HDU 5715 XOR 游戏 二分+字典树
XOR 游戏 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5715 Description 众所周知,度度熊喜欢XOR运算(XOR百科). 今天,它 ...
- Manthan, Codefest 16 C. Spy Syndrome 2 字典树 + dp
C. Spy Syndrome 2 题目连接: http://www.codeforces.com/contest/633/problem/C Description After observing ...
- UVALive 3942 Remember the Word 字典树+dp
/** 题目:UVALive 3942 Remember the Word 链接:https://vjudge.net/problem/UVALive-3942 题意:给定一个字符串(长度最多3e5) ...
- Codeforces Round #311 (Div. 2) E - Ann and Half-Palindrome(字典树+dp)
E. Ann and Half-Palindrome time limit per test 1.5 seconds memory limit per test 512 megabytes input ...
- HDU4825 Xor Sum(字典树解决最大异或问题)
Zeus 和 Prometheus 做了一个游戏,Prometheus 给 Zeus 一个集合,集合中包含了N个正整数,随后 Prometheus 将向 Zeus 发起M次询问,每次询问中包含一个正整 ...
- LA 3942 - Remember the Word (字典树 + dp)
https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemid=8&page=show_probl ...
- CF456D A Lot of Games (字典树+DP)
D - A Lot of Games CF#260 Div2 D题 CF#260 Div1 B题 Codeforces Round #260 CF455B D. A Lot of Games time ...
- HDU--5269 ZYB loves Xor I (字典树)
题目电波: HDU--5269 ZYB loves Xor I 首先我们先解决 ai xor aj 每个数转化为二进制 我们用字典树统计 每个节点 0 和 1 的出现的个数 #include< ...
- BZOJ 4260 Codechef REBXOR (区间异或和最值) (01字典树+DP)
<题目链接> 题目大意:给定一个序列,现在求出两段不相交的区间异或和的最大值. 解题分析: 区间异或问题首先想到01字典树.利用前缀.后缀建树,并且利用异或的性质,相同的两个数异或变成0, ...
随机推荐
- Thread的第五天学习
1.如果每个线程执行的代码相同,可以使用同一个Runnable对象,这个Runnable对象中有那个共享数据,例如:卖票系统就可以这么做! package com.thread.demo; publi ...
- Cache 应用程序数据缓存
System.Web.Caching 命名空间提供用于缓存服务器上常用数据的类.此命名空间包括 Cache 类,该类是一个字典,您可以在其中存储任意数据对象,如哈希表和数据集.它还为这些对象提供了失效 ...
- 使用PowerDesigner进行数据库建模入门
阅读目录 两种重要模型 创建表和主外键 创建视图和存储过程 生成数据库 PowerDesigner(简称PD)是一种强大的数据库建模工具,使用PD可以创建业务模型,UML类图等,当然最主要的功能是数据 ...
- Linux中断处理体系结构分析
Linux中断处理体系结构分析(一) 异常,就是可以打断CPU正常运行流程的一些事情,比如外部中断.未定义指令.试图修改只读的数据.执行swi指令(Software Interrupt Instruc ...
- 如何发布使用LGPL版Qt的商业软件
最近做跨平台图形用户界面库选型,权衡很多因素后最终选择了Qt,其中一个重要因素就是Qt使用LGPL授权许可.由于本人对LGPL理解有限,始终对闭源商业软件如何发布Qt库存在疑问,其中最关心的是:发布的 ...
- arcgis api for javascript 出现 undefinedModule错误
一般都是script代码里面语法错误,如. .;:之类的
- C# Java间进行RSA加密解密交互
原文:C# Java间进行RSA加密解密交互 这里,讲一下RSA算法加解密在C#和Java之间交互的问题,这两天纠结了很久,也看了很多其他人写的文章,颇受裨益,但没能解决我的实际问题,终于,还是被我捣 ...
- RedHat6配置yum源 (32位)
由于 redhat的yum在线更新是收费的,如果没有注册的话不能使用, 如果要使用,需将redhat的yum卸载后,重启安装,再配置其他源,以下为详细过程: 1.删除redhat原有的yum rpm ...
- Maven基本操作命令
1.mvn package 此命令包含一系列过程:validate-->compile-->test-->package Maven根据pom文件里packaging的配置,决定是生 ...
- opencv 图像阴影检测
参数说明: IplImage *workImg-当前全局变量,表示正在显示的图片. downleft, upright- 检测出的阴影部分矩形框的两个对角顶点. /****************** ...