UVA 12232 - Exclusive-OR(带权并查集)
UVA 12232 - Exclusive-OR
题意:有n个数字。一開始值都不知道,每次给定一个操作,I a v表示确认a值为v,I a b v,表示确认a^b = v,Q k a1 a2 a3 ... ak。表示推断这些数字的异或值是否能确定。能确定就输出值,假设有矛盾就停止
思路:带权并查集,权表示和父结点的异或值,那么多数推断的时候,仅仅要全部数字和他的父结点的异或值的异或值。假设父结点的个数是偶数个。那么依据异或的性质能抵消掉,是能够判定的。假设不为偶数,就是不能判定。
注意第一种操作,要加个小处理,就是多一个虚拟结点,保证虚拟结点始终为根。虚拟结点代表0。这样仅仅要连到虚拟结点上。第一种和另外一种操作事实上就是一样的了
代码:
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std; const int N = 20005; int n, qn, parent[N], val[N], vis[N];
struct query {
char c;
int a, b, v, k, x[20];
} q[2 * N]; int find(int x) {
if (x == parent[x]) return x;
int tmp = parent[x];
parent[x] = find(parent[x]);
val[x] ^= val[tmp];
return parent[x];
} void init() {
for (int i = 0; i <= n; i++) {
parent[i] = i;
val[i] = 0;
}
char Q[105];
for (int i = 0; i < qn; i++) {
scanf("%s", Q);
q[i].c = Q[0];
int a, b, v;
if (Q[0] == 'I') {
gets(Q);
if (sscanf(Q, "%d%d%d", &a, &b, &v) == 2) {
v = b; b = n;
}
q[i].a = a; q[i].b = b; q[i].v = v;
}
else {
scanf("%d", &q[i].k);
for (int j = 0; j < q[i].k; j++)
scanf("%d", &q[i].x[j]);
}
}
} void solve() {
int fir = 0;
for (int i = 0; i < qn; i++) {
if (q[i].c == 'I') {
fir++;
int pa = find(q[i].a);
int pb = find(q[i].b);
if (pa == n) swap(pa, pb);
if (pa == pb) {
if ((val[q[i].a]^val[q[i].b]) != q[i].v) {
printf("The first %d facts are conflicting.\n", fir);
return;
}
}
else {
parent[pa] = pb;
val[pa] = val[q[i].a]^val[q[i].b]^q[i].v;
}
}
else {
int ans = 0;
for (int j = 0; j < q[i].k; j++) {
int px = find(q[i].x[j]);
ans ^= val[q[i].x[j]];
if (px != n)
vis[px] ^= 1;
}
int flag = 1;
for (int j = 0; j < q[i].k; j++) {
if (vis[parent[q[i].x[j]]])
flag = 0;
vis[parent[q[i].x[j]]] = 0;
}
if (flag) printf("%d\n", ans);
else printf("I don't know.\n");
}
}
} int main() {
int cas = 0;
while (~scanf("%d%d", &n, &qn) && n) {
init();
printf("Case %d:\n", ++cas);
solve();
printf("\n");
}
return 0;
}
UVA 12232 - Exclusive-OR(带权并查集)的更多相关文章
- UVA 3027 Corporative Network 带权并查集、
题意:一个企业要去收购一些公司把,使的每个企业之间互联,刚开始每个公司互相独立 给出n个公司,两种操作 E I:询问I到I它连接点最后一个公司的距离 I I J:将I公司指向J公司,也就是J公司是I公 ...
- UVA - 10004 Bicoloring(判断二分图——交叉染色法 / 带权并查集)
d.给定一个图,判断是不是二分图. s.可以交叉染色,就是二分图:否则,不是. 另外,此题中的图是强连通图,即任意两点可达,从而dfs方法从一个点出发就能遍历整个图了. 如果不能保证从一个点出发可以遍 ...
- POJ 1703 Find them, Catch them(带权并查集)
传送门 Find them, Catch them Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 42463 Accep ...
- [NOIP摸你赛]Hzwer的陨石(带权并查集)
题目描述: 经过不懈的努力,Hzwer召唤了很多陨石.已知Hzwer的地图上共有n个区域,且一开始的时候第i个陨石掉在了第i个区域.有电力喷射背包的ndsf很自豪,他认为搬陨石很容易,所以他将一些区域 ...
- poj1417 带权并查集 + 背包 + 记录路径
True Liars Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 2713 Accepted: 868 Descrip ...
- poj1984 带权并查集(向量处理)
Navigation Nightmare Time Limit: 2000MS Memory Limit: 30000K Total Submissions: 5939 Accepted: 2 ...
- 【BZOJ-4690】Never Wait For Weights 带权并查集
4690: Never Wait for Weights Time Limit: 15 Sec Memory Limit: 256 MBSubmit: 88 Solved: 41[Submit][ ...
- hdu3038(带权并查集)
题目链接: http://acm.split.hdu.edu.cn/showproblem.php?pid=3038 题意: n表示有一个长度为n的数组, 接下来有m行形如x, y, d的输入, 表示 ...
- 洛谷OJ P1196 银河英雄传说(带权并查集)
题目描述 公元五八○一年,地球居民迁移至金牛座α第二行星,在那里发表银河联邦 创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发战争.泰山 ...
随机推荐
- http://blog.csdn.net/luoshengyang/article/details/6651971
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6651971 在Android系统中,提供了独特 ...
- Android进程间通信(IPC)机制Binder简要介绍和学习计划
文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/6618363 在Android系统中,每一个应用 ...
- java中的二进制
(1)按位与运算 & 1 & 1 = 1, 0 & 1 = 0 51 & 5 即 0011 0011 & 0000 0101 =0000 0001 = 1 ...
- Oracle-nomount/mount/open
通常所说的Oracle Server主要由两个部分组成:Instance和Database.Instance是指一组后台进程(在Windows上是一组线程)和一块共享内存区域:Database是指存储 ...
- asp.net MVC 学习笔记
1.可以看出每个区域Areas里都是个mini的MVC项目,Controller.Models.Views一个都不缺,还多了一个AdminAreaRegistration类 2.MVC 将URL映射到 ...
- 跨平台渲染框架尝试 - Texture管理
纹理是渲染器重要的资源,也是比较简单的资源.本文将详细讨论纹理资源的管理. 在资源管理概述中提到,资源就是一堆内存和CPU与GPU的访问权限.纹理管理在资源管理之上,要负责如何使用者一堆内存构造纹理对 ...
- 【转】nginx之主配置文件:root和alias
nginx指定文件路径有两种方式root和alias,这两者的用法区别,使用方法总结了下,方便大家在应用过程中,快速响应.root与alias主要区别在于nginx如何解释location后面的uri ...
- werkzeug源码阅读笔记(二) 上
因为第一部分是关于初始化的部分的,我就没有发布出来~ wsgi.py----第一部分 在分析这个模块之前, 需要了解一下WSGI, 大致了解了之后再继续~ get_current_url()函数 很明 ...
- BC 65 game
主持人一直某个数字在1到n范围,假设甲乙已经知道,甲先猜乙后,都采用最优策略,主持人说偏大还是偏小,不断缩小范围,问最后乙能会获胜的X的取值的个数. 如果n为奇数,那么仅当x=n/2乙必然获胜,若为奇 ...
- 【转】iOS代码规范
原文地址: http://www.cocoachina.com/ios/20150908/13335.html 简介: 本 文整理自Apple文档<Coding Guidelines for C ...