hdu3234 带权并查集(XOR)
题意:
给你n个未知的正整数,有三总操作
I P V P的值是V
I P Q V P XOR Q = V
Q K x1 x2....xk 求这k个数所有异或后的值
思路:
带权并查集,感觉这个题目用的很巧,设计到以下知识,a ^ b = c ,a ^ c = b ,b
^ c = a他们三个是等价的,还有就是a ^ b ^ a = b ,这个题目自己好好画画就出来了,确定好带权并查集后可以虚拟出来一个点,把它做为真实点,就是如果谁的根是他那么这个值就已经确定了,我虚拟的是0点,把其他的点都映射成+1,还有就是这个题目的核心部分就是查询的那个地方,除了确定的点,其他的必须是每个集合都出现了偶数个的时候才能算出来,原因就是“性质不同的数不能乘在一起,要么就是相对位置相乘,要么就是确定的数字相乘,两个相对位置相乘的到的是确定的数字,确定的数字相乘得到的还是确定的数字”,这个题目设计到很多细节,我就不说了,谁做谁知道啊!
还有就是提醒个最坑的地方 a ^ b != c 他和 (a ^ b) != c不是等价的,优先级的原因。其他的做的时候就知道了,今天手残,这个题目做了17次才AC.
#include<stdio.h>
#include<string.h> #define N 22000
int mer[N] ,Xor[N];
int ss[N]; int finds(int x)
{
if(x == mer[x]) return x;
int t = mer[x];
mer[x] = finds(mer[x]);
Xor[x] = Xor[x] ^ Xor[t];
return mer[x];
} int main ()
{
int n ,m ,i ,j ,num ,p ,q ,v ,k;
int n1 ,n2 ,n3 ,cas = 1 ,fact ,stop;
char str[10] ,c;
while(~scanf("%d %d" ,&n ,&m) && n + m)
{
printf("Case %d:\n" ,cas ++);
for(i = 0 ;i <= n ;i ++)
mer[i] = i ,Xor[i] = 0;
for(stop = fact = 0 ,i = 1 ;i <= m ;i ++)
{
scanf("%s" ,str);
if(str[0] == 'I')
{
fact ++; int ii = 0;
while(1)
{
scanf("%d%c" ,&num ,&c);
ii ++;
if(ii == 1) n1 = num;
if(ii == 2) n2 = num;
if(ii == 3) n3 = num;
if(c == '\n') break;
}
if(stop) continue;
if(ii == 2)
{
p = n1 + 1 ,v = n2;
int x = finds(p);
if(!x)
{
if(Xor[p] == v) continue;
stop = 1;
printf("The first %d facts are conflicting.\n" ,fact ++);
}
else
{
mer[x] = 0;
Xor[x] = Xor[p] ^ v;
}
}
if(ii == 3)
{
p = n1 + 1 ,q = n2 + 1 ,v = n3;
int x = finds(p) ,y = finds(q);
if(x == y)
{
if((Xor[p] ^ Xor[q]) == v) continue;
stop = 1;
printf("The first %d facts are conflicting.\n" ,fact ++);
}
else
{
if(y)
{
mer[y] = x;
Xor[y] = Xor[p] ^ Xor[q] ^ v;
}
else
{
mer[x] = y;
Xor[x] = Xor[p] ^ Xor[q] ^ v;
}
}
}
}
else
{
scanf("%d" ,&k);
memset(ss ,0 ,sizeof(ss));
int sum = 0 ,mk = 0;
for(j = 1 ;j <= k ;j ++)
{
scanf("%d" ,&num);
num ++;
ss[finds(num)] ++;
sum = sum ^ Xor[num];
}
for(j = 1 ;j <= n ;j ++)
if(ss[j] & 1) mk = 1;
if(stop) continue;
if(mk) puts("I don't know.");
else printf("%d\n" ,sum);
}
}
puts("");
}
return 0;
}
hdu3234 带权并查集(XOR)的更多相关文章
- 【uva12232/hdu3461】带权并查集维护异或值
题意: 对于n个数a[0]~a[n-1],但你不知道它们的值,通过逐步提供给你的信息,你的任务是根据这些信息回答问题: I P V :告诉你a[P] = V I P Q V:告诉你a[P] XOR a ...
- 2017乌鲁木齐区域赛I(带权并查集)
#include<bits/stdc++.h>using namespace std;int f[200010];//代表元long long rl[200010];//记rl[i]为结点 ...
- 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 银河英雄传说(带权并查集)
题目描述 公元五八○一年,地球居民迁移至金牛座α第二行星,在那里发表银河联邦 创立宣言,同年改元为宇宙历元年,并开始向银河系深处拓展. 宇宙历七九九年,银河系的两大军事集团在巴米利恩星域爆发战争.泰山 ...
随机推荐
- Python基础之:Python中的流程控制
目录 简介 while语句 if 语句 for语句 Break Continue pass 简介 流程控制无非就是if else之类的控制语句,今天我们来看一下Python中的流程控制会有什么不太一样 ...
- Kubernetes Container lifecycle hooks
简介 在kubernetes中,容器hooks旨在解决服务进程启动与停止时的一些优雅操作需求.比如说进程停止时要给进程一个清理数据的时间,保证服务的请求正常结束,而不是强行中断服务的运行,这样在生产环 ...
- Java volatile关键字详解
Java volatile关键字详解 volatile是java中的一个关键字,用于修饰变量.被此关键修饰的变量可以禁止对此变量操作的指令进行重排,还有保持内存的可见性. 简言之它的作用就是: 禁止指 ...
- [BJWC2018] Kakuro
一.题目 点此看题 二.解法 我一开始一直想不出来,直接刚这个题实在是太复杂了,因为一开始就是不合法的. 下次遇到复杂的题一定要想 调整法 ,我再不往这个方向想我吔屎 好了言归正传,我们先找一组可行的 ...
- 2018.8.30 nowcoder oi赛制测试1
2018.8.30 nowcoder oi赛制测试1 普及组难度,发现了一些问题 A 题目大意:求斐波那契数列\(f(k-1)f(k+1)-f(k)^2\),范围极大 打表可得规律 其实是卡西尼恒等式 ...
- incubator-dolphinscheduler 如何在不写任何新代码的情况下,能快速接入到prometheus和grafana中进行监控
一.prometheus和grafana 简介 prometheus是由谷歌研发的一款开源的监控软件,目前已经贡献给了apache 基金会托管. 监控通常分为白盒监控和黑盒监控之分. 白盒监控:通过监 ...
- python自动统计zabbix系统监控覆盖率
脚本主要功能: 1)通过zabbix api接口采集所有监控主机ip地址: 2)通过cmdb系统(蓝鲸)接口采集所有生产主机IP地址.主机名.操作系统.电源状态: 3)以上2步返回数据对比,找出未监控 ...
- PAT (Advanced Level) Practice 1002 A+B for Polynomials (25 分) 凌宸1642
PAT (Advanced Level) Practice 1002 A+B for Polynomials (25 分) 凌宸1642 题目描述: This time, you are suppos ...
- 使用 Elastic 技术栈构建 Kubernetes全栈监控
以下我们描述如何使用 Elastic 技术栈来为 Kubernetes 构建监控环境.可观测性的目标是为生产环境提供运维工具来检测服务不可用的情况(比如服务宕机.错误或者响应变慢等),并且保留一些可以 ...
- [Fundamental of Power Electronics]-PART I-4.开关实现-4.2 功率半导体器件概述
4.2 功率半导体器件概述 功率半导体设计中最根本的挑战是获得高击穿电压,同时保持低正向压降和导通电阻.一个密切相关的问题是高压低导通电阻器件的开关时间更长.击穿电压,导通电阻和开关时间之间的折衷是各 ...