[Bzoj4195] [NOI2015] 程序自动分析 [并查集,哈希,map] 题解
用并查集+离散化,注意:并查集数组大小不是n而是n*2
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <ctime>
#include <map> using namespace std; int fa[],a[],b[],op[]; inline int get_anc(const int x)
{
return fa[x]==x ? x:fa[x]=get_anc(fa[x]);
} int main()
{
int i,n,q,S,T,cnt=; scanf("%d",&q);
while(q--)
{
scanf("%d",&n);
map<int,int> Map;
Map.clear();cnt=;
for(i=;i<=n<<;++i)fa[i]=i; for(i=;i<=n;++i)scanf("%d%d%d",&a[i],&b[i],&op[i]); for(i=;i<=n;++i)
{
if(op[i])
{
if(!Map[a[i]])Map[a[i]]=++cnt;
if(!Map[b[i]])Map[b[i]]=++cnt;
int x=Map[a[i]],y=Map[b[i]];
S=get_anc(x),T=get_anc(y);
if(S!=T)fa[S]=T;
}
} for(i=;i<=n;++i)
{
if(!op[i])
{
if(!Map[a[i]])Map[a[i]]=++cnt;
if(!Map[b[i]])Map[b[i]]=++cnt;
int x=Map[a[i]],y=Map[b[i]];
S=get_anc(x),T=get_anc(y);
if(S==T)
{
printf("NO\n");
goto Fail;
}
}
} printf("YES\n");
Fail:;
} return ;
}
[Bzoj4195] [NOI2015] 程序自动分析 [并查集,哈希,map] 题解的更多相关文章
- [BZOJ4195] [NOI2015] 程序自动分析 (并查集)
		
Description 在实现程序自动分析的过程中,常常需要判定一些约束条件是否能被同时满足. 考虑一个约束满足问题的简化版本:假设x1,x2,x3,…代表程序中出现的变量,给定n个形如xi=xj或x ...
 - bzoj4195 [Noi2015]程序自动分析——并查集
		
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=4195 突然在这道大水题上WA了半天... 思路很简单,离线处理询问,先把 = 的都加到并查集 ...
 - 【BZOJ4195】[Noi2015]程序自动分析 并查集
		
[BZOJ4195][Noi2015]程序自动分析 Description 在实现程序自动分析的过程中,常常需要判定一些约束条件是否能被同时满足. 考虑一个约束满足问题的简化版本:假设x1,x2,x3 ...
 - BZOJ-4195 NOI2015Day1T1 程序自动分析   并查集+离散化
		
总的来说,这道题水的有点莫名奇妙,不过还好一次轻松A 4195: [Noi2015]程序自动分析 Time Limit: 10 Sec Memory Limit: 512 MB Submit: 836 ...
 - BZOJ 4195: [Noi2015]程序自动分析 并查集+离散化
		
LUOGU 1955BZOJ 4195 题目描述 在实现程序自动分析的过程中,常常需要判定一些约束条件是否能被同时满足. 考虑一个约束满足问题的简化版本:假设x1,x2,x3...代表程序中出现的变量 ...
 - 洛谷P1955 [NOI2015] 程序自动分析 [并查集,离散化]
		
题目传送门 题目描述 在实现程序自动分析的过程中,常常需要判定一些约束条件是否能被同时满足. 考虑一个约束满足问题的简化版本:假设x1,x2,x3...代表程序中出现的变量,给定n个形如xi=xj或x ...
 - BZOJ 4195: [Noi2015]程序自动分析 [并查集 离散化 | 种类并查集WA]
		
题意: 给出若干相等和不等关系,判断是否可行 woc NOI考这么傻逼的题飞快打了一个种类并查集交上了然后爆零... 发现相等和不等看错了异或一下再叫woc90分 然后发现md$a \neq b, a ...
 - NOI2015程序自动分析 并查集
		
有10^9个点,每次给出两个点的关系:权相等或不等,问最后能不能成立 感觉一开始在撕烤一个动态的问题,,,想写一个带权的并查集 结果发现静态询问,那就sb乱搞,懒得手写离散就直接map(卧槽好多细节忘 ...
 - BZOJ 4195: [Noi2015]程序自动分析 并查集 + 离散化 + 水题
		
TM 读错题了...... 我还以为是要动态询问呢,结果是统一处理完了再询问...... 幼儿园题,不解释. Code: #include<bits/stdc++.h> #define m ...
 
随机推荐
- bzoj3505 [Cqoi2014]数三角形——组合数+容斥
			
题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3505 好题啊好题...好像还曾经出现在什么智力测试卷中来着...当时不会现在还是无法自己推出 ...
 - ORACLE数据删除数据删除的解决办法
			
今天主要以oracle数据库为例,介绍关于表中数据删除的解决办法.(不考虑全库备份和利用归档日志)删除表中数据有三种方法:·delete(删除一条记录)·drop或truncate删除表格中数据 1. ...
 - AbstractRoutingDataSource动态选择数据源
			
当我们项目变大后,有时候需要多个数据源,接下来我们讲一种能等动态切换数据源的例子. 盗一下图: 单数据源的场景(一般的Web项目工程这样配置进行处理,就已经比较能够满足我们的业务需求) 多数据源多Se ...
 - 让谷歌浏览器(chrome)保存调试代码workspace
			
方法/步骤 chrome浏览器早期版本的操作方法与我现在要讲的方法有所不同,因此操作前请注意浏览器的版本号. 示例中的版本号: 53.0.2785.116 m 任意打开一个需要调试的html文件 ...
 - 【XSY3209】RGB Sequence
			
题目 传送门 解法 用\(f_{i, j, k}\)表示有\(i\)个红石块, \(j\)个绿宝石块, \(k\)个钻石块 可以转移到\(f_{p+1, j, k}\). \(f_{i, p+1,k ...
 - JQuery  总结
			
JQuery官方网站 http://jquery.com/ 1.JQuery概念 A.Jquery是一个优秀的Javascript框架.它是轻量级的js库 ,它兼容CSS3,还兼容各种浏览器,jQu ...
 - redis取经之路
			
redis基本数据结构 Redis使用的是自己构建的简单动态字符串(SDS)[simple dynamic string,SDS]的抽象类型,并将SDS用做Rdis的默认字符串表示 redis> ...
 - 利用python去除红章
			
近期接的一个需求需要去除图片的红章,用到了PIL库. from PIL import Image,ImageEnhanceimport os#f="5-12 - 0001.tif" ...
 - 【java基础】java中重载与重写的区别
			
重载(Overloading) (1) 方法重载是让类以统一的方式处理不同类型数据的一种手段.多个同名函数同时存在,具有不同的参数个数/类型.重载Overloading是一个类中多态性的一种表现. ( ...
 - 【转】Java 集合系列04之 fail-fast总结(通过ArrayList来说明fail-fast的原理、解决办法)
			
概要 前面,我们已经学习了ArrayList.接下来,我们以ArrayList为例,对Iterator的fail-fast机制进行了解.内容包括::1 fail-fast简介2 fail-fast示例 ...