幸运数字(luckly)
幸运数字(luckly)
题目描述
A国共有 nn 座城市,这些城市由
条道路相连,使得任意两座城市可以互达,且路径唯一。每座城市都有一个幸运数字,以纪念碑的形式矗立在这座城市的正中心,作为城市的象征。
一些旅行者希望游览A国。旅行者计划乘飞机降落在 xx 号城市,沿着 xx 号城市到 yy 号城市之间那条唯一的路径游览,最终从 yy 城市起飞离开A国。在经过每一座城市时,游览者就会有机会与这座城市的幸运数字拍照,从而将这份幸运保存到自己身上。
然而,幸运是不能简单叠加的,这一点游览者也十分清楚。他们迷信着幸运数字是以异或的方式保留在自己身上的。例如,游览者拍了 33 张照片,幸运值分别是 5,7,115,7,11 ,那么最终保留在自己身上的幸运值就是 9(5 \ xor \ 7 \ xor \ 11)9(5 xor 7 xor 11) 。有些聪明的游览者发现,只要选择性地进行拍照,便能获得更大的幸运值。例如在上述三个幸运值中,只选择 55 和 1111 ,可以保留的幸运值为 1414 。
现在,一些游览者找到了聪明的你,希望你帮他们计算出在他们的行程安排中可以保留的最大幸运值是多少。
输入格式
第一行包含 22 个正整数 nn 、 qq ,分别表示城市的数量和旅行者数量。
第二行包含 nn 个非负整数,其中第 ii 个整数 G_iGi 表示 ii 号城市的幸运值。
随后
行,每行包含两个正整数 xx 、 yy ,表示 xx 号城市和 yy 号城市之间有一条道路相连。
随后 qq 行,每行包含两个正整数 xx 、 yy ,表示这名旅行者的旅行计划是从 xx 号城市到 yy 号城市。
输出格式
输出需要包含 qq 行,每行包含 11 个非负整数,表示这名旅行者可以保留的最大幸运值。
样例
样例输入
4 2
11 5 7 9
1 2
1 3
1 4
2 3
1 4
样例输出
14
11
数据范围与提示
【数据范围】

来源
solution
#include<cstdio>
#include<iostream>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<cmath>
#define ll long long
#define maxn 20005
using namespace std;
int n,q,f[maxn][],deep[maxn],head[maxn],tot;
ll a[maxn];
struct node{
int v,nex;
}e[maxn*];
struct xx{
ll s[];
void ins(ll k){
for(int i=;i>=;i--){
if(k&(1LL<<i)){
if(!s[i]){s[i]=k;break;}
k^=s[i];
}
}
}
void c(){
memset(s,,sizeof s);
}
}g[maxn][];
void lj(int t1,int t2){
e[++tot].v=t2;e[tot].nex=head[t1];head[t1]=tot;
}
void dfs(int k,int fa){
f[k][]=fa;g[k][].ins(a[k]);deep[k]=deep[fa]+;
for(int i=head[k];i;i=e[i].nex){
if(e[i].v==fa)continue;
dfs(e[i].v,k);
}
}
xx merge(xx A,xx B){
for(int i=;i>=;i--){
if(B.s[i]>)A.ins(B.s[i]);
}
return A;
}
ll work(int t1,int t2){
xx ans;ans.c();
if(deep[t1]<deep[t2])swap(t1,t2);
for(int x=;x>=;x--){
if(deep[f[t1][x]]>=deep[t2])ans=merge(ans,g[t1][x]),t1=f[t1][x];
}
for(int x=;x>=;x--){
if(f[t1][x]!=f[t2][x]){
ans=merge(ans,g[t1][x]),t1=f[t1][x];
ans=merge(ans,g[t2][x]),t2=f[t2][x];
}
}
if(t1!=t2)ans=merge(ans,g[t1][]),ans=merge(ans,g[t2][]),t1=f[t1][];
ans=merge(ans,g[t1][]);
ll A=;
for(int i=;i>=;i--)A=max(A,A^ans.s[i]);
return A;
}
int main()
{
cin>>n>>q;
for(int i=;i<=n;i++)scanf("%lld",&a[i]);
for(int i=,t1,t2;i<n;i++){
scanf("%d%d",&t1,&t2);
lj(t1,t2);lj(t2,t1);
}
dfs(,);
for(int j=;j<=;j++)
for(int i=;i<=n;i++){
f[i][j]=f[f[i][j-]][j-];
g[i][j]=merge(g[i][j-],g[f[i][j-]][j-]);
}
for(int i=,t1,t2;i<=q;i++){
scanf("%d%d",&t1,&t2);
printf("%lld\n",work(t1,t2));
}
return ;
}
幸运数字(luckly)的更多相关文章
- BZOJ 1853 【Scoi2010】 幸运数字
Description 在中国,很多人都把6和8视为是幸运数字!lxhgww也这样认 为,于是他定义自己的"幸运号码"是十进制表示中只包含数字6和8的那些号码,比如68,666,8 ...
- BZOJ 4568 幸运数字
题目传送门 4568: [Scoi2016]幸运数字 Time Limit: 60 Sec Memory Limit: 256 MB Description A 国共有 n 座城市,这些城市由 n-1 ...
- BZOJ 1853: [Scoi2010]幸运数字
1853: [Scoi2010]幸运数字 Time Limit: 2 Sec Memory Limit: 64 MBSubmit: 2117 Solved: 779[Submit][Status] ...
- 【BZOJ-4568】幸运数字 树链剖分 + 线性基合并
4568: [Scoi2016]幸运数字 Time Limit: 60 Sec Memory Limit: 256 MBSubmit: 238 Solved: 113[Submit][Status ...
- 【BZOJ-1853&2393】幸运数字&Cirno的完美算数教室 容斥原理 + 爆搜 + 剪枝
1853: [Scoi2010]幸运数字 Time Limit: 2 Sec Memory Limit: 64 MBSubmit: 1817 Solved: 665[Submit][Status] ...
- BZOJ1853 [Scoi2010]幸运数字
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000作者博客:http://www.cnblogs.com/ljh2000-jump/转 ...
- 【bzoj1853】 Scoi2010—幸运数字
http://www.lydsy.com/JudgeOnline/problem.php?id=1853 (题目链接) 今天考试考了容斥,结果空知道结论却不会写→_→ 题意 求区间中不含6,8两个数字 ...
- 幸运数字(number)
幸运数字(number) Time Limit:1000ms Memory Limit:64MB [题目描述] LYK最近运气很差,例如在NOIP初赛中仅仅考了90分,刚刚卡进复赛,于是它决定使用 ...
- Bzoj 1853: [Scoi2010]幸运数字 容斥原理,深搜
1853: [Scoi2010]幸运数字 Time Limit: 2 Sec Memory Limit: 64 MBSubmit: 1774 Solved: 644[Submit][Status] ...
随机推荐
- logrus学习笔记
logrus源码:https://github.com/sirupsen/logrus 1.logrus.Entry结构 1.1 类型 type Entry struct { Logger *Logg ...
- webmin纯web界面管理linux系统
关键字: 摘要:从Windows环境的管理转到Linux环境的管理时所面临的挑战之一是,您需要去学习利用新的工具.作为一个管理员,您希望理解操作系统的细节以发挥它的最大功效.但是,当您还处在学习阶段时 ...
- Python生成器、装饰器
## 生成器 - 生成器是用来创建Python序列的一个对象 - 通常生成器是为迭代器产生数据的 - 例如range()函数就是一个生成器 - 每次迭代生成器时,它都会记录上一次调用的位置,并返回下一 ...
- tp5.0初入
1.目录结构 |-application 应用目录 是整个网站的核心 |---|---index 前台目录 |---|-----|---controller 控制器 |---|-----|---mod ...
- Linux系统完整安装在虚拟机Mini
打开VMware Workstation虚拟机,然后如下图一步到位: 此处只是简单的安装Linux系统,要想查看安装后的IP等配置看: https://www.cnblogs.com/gentle-a ...
- JS实现禁用滑动条但滑动条不消失的效果
//方法 //滑动条 // left: 37, up: 38, right: 39, down: 40, // spacebar: 32, pageup: 33, pagedown: 34, end: ...
- C# 中的正则简单例子
public static void Main() { Regex rgx = new Regex(@"[S|s]et-[C|c]ookie: (?<cookieName>\w+ ...
- Struts2---配置文件讲解及简单登录示例
bean 用于创建一个JavaBean实例 constant 用于Struts2默认行为标签 <!-- 配置web默认编码集,相当于HttpServletRequest.setChartacte ...
- Retrofit get post query filed FiledMap
直接请求型 1.如果是直接请求某一地址,写法如下: @GET("/record") Call getResult(); 2.如果是组合后直接请求,如/result/{id}写法如下 ...
- 怎么将oracle的sql文件转换成mysql的sql文件-- 费元星
http://jingyan.baidu.com/article/ca41422fe01f251eaf99ed6e.html