幸运数字(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] ...
随机推荐
- UVa新汉诺塔问题(A Different Task,Uva 10795)
主要需要理递归函数计算 #define MAXN 60+10 #include<iostream> using namespace std; int n,k,S[MAXN],F[MAXN] ...
- lintcode_93_平衡二叉树
平衡二叉树 描述 笔记 数据 评测 给定一个二叉树,确定它是高度平衡的.对于这个问题,一棵高度平衡的二叉树的定义是:一棵二叉树中每个节点的两个子树的深度相差不会超过1. 您在真实的面试中是否遇到过 ...
- Git学习第一天--安装Git和创建版本库
Windows上安装Git msysgit是Windows版的Git,从https://git-for-windows.github.io下载(备份:百度网盘),然后按默认选项安装即可. 安装完成后, ...
- vim指令,快捷键汇总
Vim 命令.操作.快捷键全集 命令历史 以:和/开头的命令都有历史纪录,可以首先键入:或/然后按上下箭头来选择某个历史命令. 启动vim 在命令行窗口中输入以下命令即可 vim 直接启动vim vi ...
- MySQL中使用group_concat()函数数据被截取(有默认长度限制),谨慎!
最近在工作中遇到一个问题: 我们系统的一些逻辑处理是用存储过程实现的,但是有一天客服反馈说订单下单失败,查了下单牵扯到的产品基础资源,没有问题. 下单的存储过程中有这样两句代码: ; ; ; 执行存储 ...
- Xtrabackup实现MySQL备份
一.xtrabackup介绍 Xtrabackup是一个对InnoDB做数据备份的工具,支持在线热备份(备份时不影响数据读写)它由percona提供的mysql数据库备份工具,据官方介绍,这也是世界上 ...
- MAC中向阿里云服务器上传文件
打开mac中的终端 使用命令:$scp /local/file user@remote:/file /local/file 是本地文件 后面部分[用户名]@[ip地址:][服务器中的文件目录] not ...
- Pandas基本命令
关键缩写和包导入 在这个速查手册中,我们使用如下缩写: df:任意的Pandas DataFrame对象 同时我们需要做如下的引入: import pandas as pd 创建测试对象 import ...
- 统计输入任意的字符中中英文字母,空格和其他字符的个数 python
这里用到了三个函数: #判断是否为数字:str.isdigit()#是否为字母:str.isalpha()#是否为空格:str.isspace() def tongji(str): alpha = 0 ...
- elasticsearch索引和映射
目录 1. elasticsearch如何实现搜索 1.1 搜索实例 1.2 es中数据的类型 1.3 倒排索引 1.4 分析与分析器 1.4.1 什么是分析器 1.4.2 内置分析器种类 1.4.3 ...