【BZOJ4568】[Scoi2016]幸运数字 倍增+线性基
【BZOJ4568】[Scoi2016]幸运数字
Description
Input
Output
输出需要包含 q 行,每行包含 1 个非负整数,表示这名旅行者可以保留的最大幸运值。
Sample Input
11 5 7 9
1 2
1 3
1 4
2 3
1 4
Sample Output
11
题解:求LCA可以用倍增,同时,我们还可以维护f[i][j]表示从i往上的2j个点中,所有权值的线性基。然后查询的时候我们把路径上的线性基都拿出来一起消一下,贪心求最大值就行了。
#include <cstdio>
#include <cstring>
#include <iostream>
using namespace std;
const int maxn=20005;
typedef long long ll;
int n,m,cnt;
int fa[15][maxn],dep[maxn],to[maxn<<1],next[maxn<<1],head[maxn];
struct node
{
int siz;
ll v[61];
node (){memset(v,0,sizeof(v)),siz=0;}
ll gauss(ll x)
{
int i;
for(i=0;i<siz;i++) if((v[i]^x)<x) x^=v[i];
if(x)
{
v[siz++]=x;
for(i=siz-1;i;i--) if(v[i-1]<v[i]) swap(v[i-1],v[i]);
}
return x;
}
ll query()
{
ll ret=0;
for(int i=0;i<siz;i++) if((ret^v[i])>ret) ret^=v[i];
return ret;
}
}s[15][maxn];
ll rd()
{
ll ret=0; char gc=getchar();
while(gc<'0'||gc>'9') gc=getchar();
while(gc>='0'&&gc<='9') ret=ret*10+gc-'0',gc=getchar();
return ret;
}
void add(int a,int b)
{
to[cnt]=b,next[cnt]=head[a],head[a]=cnt++;
}
void dfs(int x)
{
for(int i=head[x];i!=-1;i=next[i])
if(to[i]!=fa[0][x])
fa[0][to[i]]=x,dep[to[i]]=dep[x]+1,dfs(to[i]);
}
int main()
{
//freopen("bz4568.in","r",stdin);
n=rd(),m=rd();
int i,j,k,a,b;
for(i=1;i<=n;i++) s[0][i].gauss(rd());
memset(head,-1,sizeof(head));
for(i=1;i<n;i++) a=rd(),b=rd(),add(a,b),add(b,a);
dep[1]=1,dfs(1);
for(j=1;(1<<j)<=n;j++)
{
for(i=1;i<=n;i++)
{
for(k=0;k<s[j-1][i].siz;k++) s[j][i].gauss(s[j-1][i].v[k]);
for(k=0;k<s[j-1][fa[j-1][i]].siz;k++) s[j][i].gauss(s[j-1][fa[j-1][i]].v[k]);
fa[j][i]=fa[j-1][fa[j-1][i]];
}
}
for(i=1;i<=m;i++)
{
a=rd(),b=rd();
node ans;
if(dep[a]<dep[b]) swap(a,b);
for(j=14;j>=0;j--)
{
if(dep[fa[j][a]]>=dep[b])
{
for(k=0;k<s[j][a].siz;k++) ans.gauss(s[j][a].v[k]);
a=fa[j][a];
}
}
if(a!=b)
{
for(j=14;j>=0;j--)
{
if(fa[j][a]!=fa[j][b])
{
for(k=0;k<s[j][a].siz;k++) ans.gauss(s[j][a].v[k]);
for(k=0;k<s[j][b].siz;k++) ans.gauss(s[j][b].v[k]);
a=fa[j][a],b=fa[j][b];
}
}
ans.gauss(s[0][a].v[0]),ans.gauss(s[0][b].v[0]),ans.gauss(s[0][fa[0][a]].v[0]);
}
else ans.gauss(s[0][a].v[0]);
printf("%lld\n",ans.query());
}
return 0;
}
【BZOJ4568】[Scoi2016]幸运数字 倍增+线性基的更多相关文章
- [BZOJ4568][Scoi2016]幸运数字 倍增+线性基
4568: [Scoi2016]幸运数字 Time Limit: 60 Sec Memory Limit: 256 MBSubmit: 1791 Solved: 685[Submit][Statu ...
- bzoj4568: [Scoi2016]幸运数字(LCA+线性基)
4568: [Scoi2016]幸运数字 题目:传送门 题解: 好题!!! 之前就看过,当时说是要用线性基...就没学 填坑填坑: %%%线性基 && 神犇 主要还是对于线性基的运用和 ...
- BZOJ 4568: [Scoi2016]幸运数字(倍增+线性基)
传送门 解题思路 异或最大值肯定线性基了,树上两点那么就倍增搞一搞,就维护每个点到各级祖先的线性基,时间复杂度\(O(nlog^3n)\),并不知道咋过去的. 代码 #include<iostr ...
- 【BZOJ4568】幸运数字(线性基,树链剖分,ST表)
[BZOJ4568]幸运数字(线性基,树链剖分,ST表) 题面 BZOJ Description A 国共有 n 座城市,这些城市由 n-1 条道路相连,使得任意两座城市可以互达,且路径唯一.每座城市 ...
- [BZOJ4568][SCOI2016]幸运数字(倍增LCA,点分治+线性基)
4568: [Scoi2016]幸运数字 Time Limit: 60 Sec Memory Limit: 256 MBSubmit: 2131 Solved: 865[Submit][Statu ...
- [SCOI2016]幸运数字(线性基,倍增)
[SCOI2016]幸运数字 题目描述 A 国共有 n 座城市,这些城市由 n-1 条道路相连,使得任意两座城市可以互达,且路径唯一.每座城市都有一个幸运数字,以纪念碑的形式矗立在这座城市的正中心,作 ...
- 【BZOJ 4568】 4568: [Scoi2016]幸运数字 (线性基+树链剖分+线段树)
4568: [Scoi2016]幸运数字 Description A 国共有 n 座城市,这些城市由 n-1 条道路相连,使得任意两座城市可以互达,且路径唯一.每座城市都有一个 幸运数字,以纪念碑的形 ...
- 【bzoj4568】【Scoi2016】幸运数字 (线性基+树上倍增)
Description A 国共有 n 座城市,这些城市由 n-1 条道路相连,使得任意两座城市可以互达,且路径唯一.每座城市都有一个幸运数字,以纪念碑的形式矗立在这座城市的正中心,作为城市的象征.一 ...
- 2019.03.25 bzoj4568: [Scoi2016]幸运数字(倍增+线性基)
传送门 题意:给你一棵带点权的树,多次询问路径的最大异或和. 思路: 线性基上树?? 倍增维护一下就完了. 时间复杂度O(nlog3n)O(nlog^3n)O(nlog3n) 代码: #include ...
随机推荐
- ansible 文件和目录操作
ansible file 模块参考: refer to https://docs.ansible.com/ansible/latest/modules/file_module.html?highlig ...
- 洛谷——P1962 斐波那契数列
P1962 斐波那契数列 题目背景 大家都知道,斐波那契数列是满足如下性质的一个数列: • f(1) = 1 • f(2) = 1 • f(n) = f(n-1) + f(n-2) (n ≥ 2 且 ...
- python在程序中通过Windows打开文件
import os os.startfile(r'D:\test_input.html')
- Theam,style
Theam <!-- Base application theme. --> <!--<style name="AppTheme" parent=" ...
- fauxbar.bak
{"options": { "almostdone":"0", "backup_searchEngines":" ...
- c++ 幕客网
http://m.imooc.com/course/list.html?c=cplusplus http://coding.imooc.com/ http://www.imooc.com/act/al ...
- 关于Sending build context to Docker daemon 数据很大的问题
以往进行docker build的时候都是在新建的文件夹下面进行,这次为了图方便,就直接放在开发根目录下进行build,这样子问题就来了.于是就有了下面的文件大小发送量: Sending build ...
- cordova热更新插件调试
有更新www目录内容后,首先sencha app build,然后进入 cordova目录 运行 cordova-hcp build, 然后查看 chcp.json文件时间,然后压缩cordova目录 ...
- Exception:System.Threading.SemaphoreFullException
ylbtech-Error-Exception-C#: System.Threading.SemaphoreFullException 1.A,异常类型返回顶部 1,异常名称System.Thr ...
- Android中的Telephony学习笔记(2)
上一篇文章中学习了android.provider中Telephony类. 这一篇文章学习android.telephony包中的类,这些类是android提供给上层调用的API. 为监測基本电话信息 ...