题目大意

  假设x1,x2,x3...代表程序中出现的变量,给定n个形如xi=xj或xi≠xj的变量相等/不等的约束条件,请判定是否可以分别为每一个变量赋予恰当的值,使得上述所有约束条件同时被满足。i,j<=1000000000, n<=1000000

思路

  如果把所有相等的变量纳为一个或几个集合,那么输出yes当且仅当同一个相等集合中不存在一对xi,xj被要求不相等。集合→并查集。i,j,n的范围→离散化。

离散化的标准做法

功能

  将离散的数据压缩到一个有限的区间处理。具体可以为输入一个数的下标,输出该下标的排名。

实现

  将原始下标排序,得到一个下标为原始下标排名顺序、值为原始下标的数组。然后我们就可以运用LowerBound二分由原始下标找到其在原数组中的位置了。

注意事项

并查集

  • 一开始所有节点的Father都是自己。
  • Join两个节点是将一个节点的Root的Father设为另一个节点的Root,而不是将节点的Father设为另一个节点。

整体

  • 如果只想得到70分的话,注意下标范围是多于N的,所以并查集中的N都应当设为1000000。
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
#include <cstdlib>
using namespace std; const int MAX_N = 200010; struct Discret
{
private:
int SortedA[MAX_N];
int Rank[MAX_N];
int N; int LowerBound(int *a, int l, int r, int k)
{
while (l < r)
{
int mid = (l + r) / 2;
if (k <= SortedA[mid])
r = mid;
else
l = mid + 1;
}
return l;
} public:
void Init(int n, int *a)
{
N = n;
for (int i = 1; i <= n; i++)
SortedA[i] = a[i];
sort(SortedA + 1, SortedA + n + 1); int prevVal = 0, rankCnt = 0;
for (int i = 1; i <= n; i++)
{
if (SortedA[i] != prevVal)
{
Rank[i] = ++rankCnt;
prevVal = SortedA[i];
}
else
Rank[i] = rankCnt;
}
} int GetRank(int val)
{
return Rank[LowerBound(SortedA, 1, N, val)];
} }List; struct UnionFind
{
private:
struct Node
{
Node *Father;
}_nodes[MAX_N]; Node *GetRoot(Node *cur)
{
return cur->Father == cur ? cur : cur->Father = GetRoot(cur->Father);
} public:
void Init(int n)
{
for (int i = 1; i <= n; i++)
_nodes[i].Father = _nodes + i;
} bool SameRoot(int a, int b)
{
Node *root1 = GetRoot(_nodes + a);
Node *root2 = GetRoot(_nodes + b);
return root1 == root2;
} void Join(int a, int b)
{
GetRoot(_nodes + a)->Father = GetRoot(_nodes + b);
}
}G; int main()
{
#ifdef _DEBUG
freopen("c:\\noi\\source\\input.txt", "r", stdin);
#endif
static vector< pair<int, int> > equal, nequal;
static int OrgVal[MAX_N];
int caseCnt;
scanf("%d", &caseCnt);
while (caseCnt--)
{
equal.clear();
nequal.clear(); int n;
scanf("%d", &n);
for (int i = 1; i <= n; i++)
{
int x1, x2, isEqual;
scanf("%d%d%d", &x1, &x2, &isEqual); if (isEqual)
equal.push_back(pair<int, int>(x1, x2));
else
nequal.push_back(pair<int, int>(x1, x2)); OrgVal[i * 2 - 1] = x1;
OrgVal[i * 2] = x2;
}
List.Init(n * 2, OrgVal);
G.Init(n * 2);
for (int i = 0; i < equal.size(); i++)
{
int rank1 = List.GetRank(equal[i].first), rank2 = List.GetRank(equal[i].second);
if (!G.SameRoot(rank1, rank2))
G.Join(rank1, rank2);
} bool Ok = true;
for (int i = 0; i<nequal.size(); i++)
{
int rank1 = List.GetRank(nequal[i].first), rank2 = List.GetRank(nequal[i].second);
if (G.SameRoot(rank1, rank2))
{
Ok = false;
break;
}
}
if (Ok)
printf("YES\n");
else
printf("NO\n");
}
return 0;
}

  

luogu1955 [NOI2015] 程序自动分析的更多相关文章

  1. codevs4600 [NOI2015]程序自动分析==洛谷P1955 程序自动分析

    4600 [NOI2015]程序自动分析  时间限制: 1 s  空间限制: 256000 KB  题目等级 : 黄金 Gold 题解  查看运行结果     题目描述 Description 在实现 ...

  2. Codevs 4600 [NOI2015]程序自动分析

    4600 [NOI2015]程序自动分析 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 黄金 Gold 传送门 题目描述 Description 在实现程序自动分析的过程中,常常需 ...

  3. BZOJ4195 [Noi2015]程序自动分析(离散化+并查集)

    4195: [Noi2015]程序自动分析 Time Limit: 10 Sec  Memory Limit: 512 MB Submit: 689  Solved: 296 [Submit][Sta ...

  4. BZOJ4195 NOI2015 程序自动分析

    4195: [Noi2015]程序自动分析 Time Limit: 10 Sec Memory Limit: 512 MB Description 在实现程序自动分析的过程中,常常需要判定一些约束条件 ...

  5. 【BZOJ4195】[Noi2015]程序自动分析 并查集

    [BZOJ4195][Noi2015]程序自动分析 Description 在实现程序自动分析的过程中,常常需要判定一些约束条件是否能被同时满足. 考虑一个约束满足问题的简化版本:假设x1,x2,x3 ...

  6. bzoj 4195: [Noi2015]程序自动分析

    4195: [Noi2015]程序自动分析 Description 在实现程序自动分析的过程中,常常需要判定一些约束条件是否能被同时满足. 考虑一个约束满足问题的简化版本:假设x1,x2,x3,…代表 ...

  7. [UOJ#127][BZOJ4195][NOI2015]程序自动分析

    [UOJ#127][BZOJ4195][NOI2015]程序自动分析 试题描述 在实现程序自动分析的过程中,常常需要判定一些约束条件是否能被同时满足. 考虑一个约束满足问题的简化版本:假设x1,x2, ...

  8. [NOI2015]程序自动分析(并查集,离散化)

    [NOI2015]程序自动分析 Description 在实现程序自动分析的过程中,常常需要判定一些约束条件是否能被同时满足. 考虑一个约束满足问题的简化版本:假设x1,x2,x3,-代表程序中出现的 ...

  9. [NOI2015]程序自动分析(并查集)

    题目描述 在实现程序自动分析的过程中,常常需要判定一些约束条件是否能被同时满足. 考虑一个约束满足问题的简化版本:假设x1,x2,x3...代表程序中出现的变量,给定n个形如xi=xj或xi≠xj的变 ...

随机推荐

  1. POJ 1149 PIGS (AC这道题很不容易啊)网络流

    PIGS Description Mirko works on a pig farm that consists of M locked pig-houses and Mirko can't unlo ...

  2. hbase无法启动,The node /hbase is not in ZooKeeper

    问题详细描述如下: 2016-12-09 15:10:39,160 ERROR [org.apache.hadoop.hbase.client.ConnectionManager$HConnectio ...

  3. JQuery 动态创建表单,并自动提交

    前言:写这个是为了实现使用cookie进行自动登录的功能, 下面的代码是一个元素一个元素进行创建和赋值的, (可以尝试下将所有的html代码(form.input)全部拼好以后放到${ } 中,再进行 ...

  4. 《java数据结构与算法》系列之“简单排序"-冒泡,选择,插入

    好几天又没写,因为这几天很闲,平时忙的时候自己再累都不会睡着,但是呢这没事了,照理说应该是不瞌睡了,结果还睡着了. 所以说,人很贱.也验证了一句话,没有目标的人其实最无聊.人一定要有自己的工作,这工作 ...

  5. JNDI连接池连接Oracle数据库

    今天做了一个评论的小功能,要求用JNDI连接池连接Oracle数据库,以前只是测试了是否连接的上,现在没想到一个JNDI连接池连接Oracle数据库,纠结了好久,原来都是Oracle数据库的问题,这是 ...

  6. php实现非对称加密

    <?php /** * 使用openssl实现非对称加密 * * @since 2015-11-10 */ class Rsa { /** * 私钥 * */ private $_privKey ...

  7. css3基础篇三

    CSS3 文本阴影 在 CSS3 中,text-shadow 可向文本应用阴影. 您能够规定水平阴影.垂直阴影.模糊距离,以及阴影的颜色: 实例 向标题添加阴影: h1 { text-shadow: ...

  8. Oracle中REGEXP_SUBSTR函数

    Oracle中REGEXP_SUBSTR函数 Oracle中REGEXP_SUBSTR函数的使用说明: 题目如下: 在oracle中,使用一条语句实现将'17,20,23'拆分成'17','20',' ...

  9. React Native - 使用Geolocation进行定位(获取当前位置、监听位置变化)

    1,getCurrentPosition()方法介绍 static getCurrentPosition(geo_success, geo_error?, geo_options? 该方法用于获取当前 ...

  10. Docker拉取images时报错Error response from daemon

    docker拉取redis时,抛出以下错误: [master@localhost ~]$ docker pull redis Using default tag: latest Error respo ...