P2420 让我们异或吧

题目描述

异或是一种神奇的运算,大部分人把它总结成不进位加法.

在生活中…xor运算也很常见。比如,对于一个问题的回答,是为1,否为0.那么:

(A是否是男生 )xor( B是否是男生)=A和B是否能够成为情侣

好了,现在我们来制造和处理一些复杂的情况。比如我们将给出一颗树,它很高兴自己有N个结点。树的每条边上有一个权值。我们要进行M次询问,对于每次询问,我们想知道某两点之间的路径上所有边权的异或值。

输入输出格式

输入格式:

输入文件第一行包含一个整数N,表示这颗开心的树拥有的结点数,以下有N-1行,描述这些边,每行有3个数,u,v,w,表示u和v之间有一条权值为w的边。接下来一行有一个整数M,表示询问数。之后的M行,每行两个数u,v,表示询问这两个点之间的路径上的权值异或值。

输出格式:

输出M行,每行一个整数,表示异或值

输入输出样例

输入样例#1: 复制

5
1 4 9644
2 5 15004
3 1 14635
5 3 9684
3
2 4
5 4
1 1

输出样例#1: 复制

975
14675
0

说明

对于40%的数据,有1 ≤ N,M ≤ 3000;

对于100%的数据,有1 ≤ N ,M≤ 100000。

思路:这个题目最重要的是知道 同一个数异或两遍相当于没有异或。

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define MAXN 100001
using namespace std;
int n,m,tot;
int dad[MAXN],dis[MAXN];
int to[MAXN*2],cap[MAXN*2],net[MAXN*2],head[MAXN];
void add(int u,int v,int w){to[++tot]=v;net[tot]=head[u];cap[tot]=w;head[u]=tot;to[++tot]=u;net[tot]=head[v];cap[tot]=w;head[v]=tot;
}
void dfs(int now){for(int i=head[now];i;i=net[i])if(dad[now]!=to[i]){dad[to[i]]=now;dis[to[i]]=dis[now]^cap[i];dfs(to[i]);}
}
int main(){scanf("%d",&n);for(int i=1;i<n;i++){int u,v,w;scanf("%d%d%d",&u,&v,&w);add(u,v,w);}dfs(1);cin>>m;for(int i=1;i<=m;i++){int u,v;scanf("%d%d",&u,&v);cout<<(dis[u]^dis[v])<<endl;}
}

转载于:https://www.cnblogs.com/cangT-Tlan/p/8484763.html

洛谷 P2420 让我们异或吧相关推荐

  1. 洛谷 P2420 让我们异或吧 解题报告

    P2420 让我们异或吧 题目描述 异或是一种神奇的运算,大部分人把它总结成不进位加法. 在生活中-xor运算也很常见.比如,对于一个问题的回答,是为1,否为0.那么: (A是否是男生 )xor( B ...

  2. 洛谷 P4551 最长异或路径

    题目描述 给定一棵 nn 个点的带权树,结点下标从 11 开始到 NN .寻找树中找两个结点,求最长的异或路径. 异或路径指的是指两个结点之间唯一路径上的所有节点权值的异或. 输入输出格式 输入格式: ...

  3. 01tire+洛谷P4551 最长异或路径

    题目: 给定一棵n个点的带权树,结点下标从1开始到N.寻找树中找两个结点,求最长的异或路径. 异或路径指的是指两个结点之间唯一路径上的所有边权的异或. 输入格式 第一行一个整数NN,表示点数. 接下来 ...

  4. 【洛谷4735】 最大异或和(可持久化01Trie)

    传送门 [题目分析] emmmm,似乎是个最大异或和的模板? 先将第二个操作里的式子转一下,求a[p]^a[p+1]^....a[n]^x等价于前缀异或和sum[p-1]^sum[n]^x,后面两个的 ...

  5. YBTOJ洛谷P4551:最长异或路径(trie树)

    洛谷传送门 文章目录 题目描述 解析 代码 题目描述 解析 本题关键就在于一点: 若把每个点的深度dep[i]定义为从根到节点边权的异或和 那么i到j的路径异或和可以表示为: dep[i] ^ dep ...

  6. 洛谷P4735 最大异或和

    题目链接 洛谷P4735 最大异或和 题目描述 给定一个非负整数序列 a{a}a,初始长度为nnn. 有 mmm 个操作,有以下两种操作类型: A x:添加操作,表示在序列末尾添加一个数 xxx,序列 ...

  7. Bzoj3261/洛谷P4735 最大异或和(可持久化Trie)

    题面 Bzoj 洛谷 题解 显然,如果让你查询整个数列的最大异或和,建一颗\(01Trie\),每给定一个\(p\),按照二进制后反方向跳就行了(比如当前二进制位为\(1\),则往\(0\)跳,反之亦 ...

  8. 洛谷 P4735 最大异或和

    一.题目: 洛谷原题 二.思路: 这是一道可持久化trie的板子题. 三.代码: #include<iostream> #include<cstdio> #include< ...

  9. 洛谷P3688/uoj#291. [ZJOI2017]树状数组

    传送门(uoj) 传送门(洛谷) 这里是题解以及我的卡常数历程 话说后面那几组数据莫不是lxl出的这么毒 首先不难发现这个东西把查询前缀和变成了查询后缀和,结果就是查了\([l-1,r-1]\)的区间 ...

最新文章

  1. Spring Boot神操作-多个数据源Service层封装
  2. 每张脸值5美元,谷歌花钱买数据强化刷脸,还把隔空操控手机变成现实
  3. windows程序崩溃生成dump文件
  4. 背包九讲之五(二维费用的背包问题)
  5. C++ Primer 5th笔记(chap 16 模板和泛型编程)可变参数模板举例
  6. stl clocklist 查找元素_C++算法竞赛中常用的STL
  7. k8s问题 CrashLoopBackOff
  8. 今日腊八节,祝福送上!
  9. 創世記(一): 一至三章
  10. 对于新安装的MySQL如何提升MySQL的安全级别
  11. erf、erfc公式及其函数值表查询
  12. 旋转矩阵(Rotate Matrix)的性质分析
  13. 供应链管理的终极目标
  14. CS231n课程笔记:神经网络笔记 2
  15. 计算机网络 自顶向下方法 (一) 笔记 总结 第一章 概述
  16. 3D游戏的碰撞检测是如何实现的?
  17. CREO:CREO软件之零件【工具(调查/模型意图/实用工具)】、【视图(可见性/方向/模型显示/显示/窗口)】的简介及其使用方法(图文教程)之详细攻略
  18. libjpeg与turbo libjpeg的使用
  19. 如何利用Win7Aero特效来美化你的程序窗口
  20. 国内可以为程序员提供兼职的平台有哪些?

热门文章

  1. Java 代码细节与优化(一)
  2. Oracle translate 函数的用法, 以及和replace的区别
  3. 丁晓东_丁晓东|一种光盖过了另一种光NO.984
  4. 工业机器人调运角度_站在全球角度,看待中国工业机器人
  5. Java实现gbk utf8 转换_java项目编码格式转换(如GBK转UTF-8)
  6. vb 字符串替换_学习VB编程第69天 字符串查找与替换
  7. oracle tax 中国税,oracle_TAX_税基础设置操作手册.doc
  8. 如何发现 Kubernetes 中服务和工作负载的异常
  9. 第 19 课时:调度器的调度流程和算法介绍(木苏)
  10. ubuntu16搭建z-blog博客