【做题笔记】洛谷P1955[NOI2015]程序自动分析
第一道蓝题祭~
注意到本题中判断的是下标,即,并不是真的判断 \(i\) 是否等于 \(j\)
显然考虑并查集,把所有标记为“相等”的数放在一个集合里,然后最后扫一遍每个数,如果有两个数标记为“不等”但是在一个集合里那么说明不合法,输出 NO ,否则输出 YES。
接下来考虑一些细节
注意到在所有数据输入完后才需要输出判定结果,所以每次询问是离线的。也就是说,我们只关心这些条件是否冲突,而不关心它们出现的先后次序
所以将所有标记为“相等”的数先处理,相当于对于每一组标记为“相等”的数据,合并各自所在的并查集
注意到 \(1\ \leq\ i,j\ \leq\ 10^9\) ,数据范围很大,所以需要离散化。
离散化时注意:由于待会在用 lower_bound 查找每个数出现的位置时用的是二分查找,所以必须保证离散数组要排好序
为什么可以离散化?
注意到本题只关心每个数被标记为 \(1\) 还是 \(0\) ,不关心每个数具体的值,也不需要对一段区间(形如 \([l,r]\))进行操作,满足离散化的充要条件
每次记得把所有数组清空
需要快读
需要路径压缩
参考代码,本题细节较多,稍有不慎就会收获大红大紫大蓝,,
#include <iostream>
#include <stdio.h>
#include <string.h>
#include <algorithm>
#define ull unsigned long long
//这题需要unsigned long long
using namespace std;
int t;
struct q
{
ull i,j,e;
};
q a[10000010];
ull b[1000010*3];
//要开 3 倍!!!
ull f[1000010];
int cmp(q x,q y)
{
return x.e>y.e;
}
int get(ull x)
{
if(x==f[x]) return x;
return f[x]=get(f[x]);
}
void merge(ull x,ull y)
{
f[get(x)]=get(y);
}
inline int read()
{
int w=1,s=0;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}
while(ch>='0'&&ch<='9')s=s*10+ch-'0',ch=getchar();
return s*w;
}
int main()
{
t=read();
while(t--)
{
int n,ra=0;
n=read();
memset(a,0,sizeof(a));
memset(b,0,sizeof(b));
memset(f,0,sizeof(f));
for(int i=1;i<=n;i++)
{
a[i].i=read(),a[i].j=read(),a[i].e=read();
b[++ra]=a[i].i;
b[++ra]=a[i].j;
//离散数组 b 存放的实际上是下标(题目中的)
}
sort(b+1,b+ra+1);
int cnt=unique(b+1,b+1+ra)-b; //去重
for(int i=1;i<=n;i++)
{
a[i].i=lower_bound(b+1,b+1+cnt,a[i].i)-b;
a[i].j=lower_bound(b+1,b+1+cnt,a[i].j)-b;
}
for(int i=1;i<=cnt;i++) f[i]=i;
sort(a+1,a+n+1,cmp); //以是否被标记为相等排序,使待会先处理可以合并的操作
bool flag=true;
for(int i=1;i<=n;i++)
{
if(a[i].e) merge(a[i].i,a[i].j);
else if(get(a[i].i)==get(a[i].j))
{
printf("NO\n");
flag=false;
break;
}
}
if(flag) printf("YES\n");
}
return 0;
}
【做题笔记】洛谷P1955[NOI2015]程序自动分析的更多相关文章
- 洛谷p1955[NOI2015]程序自动分析
题目: 在实现程序自动分析的过程中,常常需要判定一些约束条件是否能被同时满足. 考虑一个约束满足问题的简化版本:假设x1,x2,x3...代表程序中出现的变量,给定n个形如xi=xj或xi≠xj的变量 ...
- 洛谷P1955 [NOI2015] 程序自动分析 [并查集,离散化]
题目传送门 题目描述 在实现程序自动分析的过程中,常常需要判定一些约束条件是否能被同时满足. 考虑一个约束满足问题的简化版本:假设x1,x2,x3...代表程序中出现的变量,给定n个形如xi=xj或x ...
- 洛谷 P1955 [NOI2015]程序自动分析 题解
每日一题 day22 打卡 Analysis 离散化+并查集 先离散化所有的约束条件,再处理所有e=1的条件,将i的祖先和j的祖先合并到一个集合中:e=0时,如果i的祖先与j的祖先在同一个集合中,说明 ...
- P1955 [NOI2015]程序自动分析
题目描述 在实现程序自动分析的过程中,常常需要判定一些约束条件是否能被同时满足. 考虑一个约束满足问题的简化版本:假设x1,x2,x3...代表程序中出现的变量,给定n个形如xi=xj或xi≠xj的变 ...
- 【luogu P1955 [NOI2015]程序自动分析】 题解
题目链接:https://www.luogu.org/problemnew/show/P1955 并查集操作,1e9要离散化,数组要开大一些,操作前先执行合并操作 样例好毒啊(全是排好序的) #inc ...
- Luogu P1955 [NOI2015]程序自动分析
又一次做了这道题,感慨万千. 记得寒假时,被cmd2001点起来讲这道题,胡言乱语..受尽鄙视(现在也是好吗)..后来下课想A掉,可是3天下来总是错...后来抄了分题解就咕咕了... 今天老师留了这道 ...
- P1955 [NOI2015]程序自动分析[离散化+并查集]
大水题一道,不明白为什么你谷评了个蓝.一看就是离散化,先去满足相等的条件,相等即为两点联通,或者说在同一个集合内.再看不相等,只有两元素在同一集合才不满足.裸的disjoint-set直接上,常数巨大 ...
- codevs4600 [NOI2015]程序自动分析==洛谷P1955 程序自动分析
4600 [NOI2015]程序自动分析 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 黄金 Gold 题解 查看运行结果 题目描述 Description 在实现 ...
- C语言程序设计做题笔记之C语言基础知识(下)
C 语言是一种功能强大.简洁的计算机语言,通过它可以编写程序,指挥计算机完成指定的任务.我们可以利用C语言创建程序(即一组指令),并让计算机依指令行 事.并且C是相当灵活的,用于执行计算机程序能完成的 ...
随机推荐
- AE开发中添加EngineOrDesktop后仍然有错误
.AO是32位原生组件,一般认为不支持64位系统(道听途说),所以只能在32位环境下进行编译. 在配置管理器中,新建x86后问题解决了
- Android_ExpandableListView
实现效果: 类似于QQ联系人列表 相关属性: android:childDivider:指定各组内子类表项之间的分隔条,图片不会完全显示, 分离子列表项的是一条直线 android:childIndi ...
- JS添加和删除表格行
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/stri ...
- HTML与W3C
HTML:超文本标记语言 超文本包括:文字.图片.音频.视频.动画等 流程:写好HTML代码后通过浏览器(自动编译HTML代码)展现出效果 HTML优点: 世界知名浏览器厂商对HTML5的支持 微软 ...
- JS 百度地图-右键菜单
JS 百度地图-右键菜单 /*-----------------标注右键删除-------------------------*/ var markerMenu = new BMap.ContextM ...
- 菜得一P!
什么时候才能改变粗心大意的坏毛病!太吃亏了...
- 牛客CSP-S提高组赛前集训营3 赛后总结
货物收集 二分答案.复杂度\(O(n\log n)\). 货物分组 用费用提前计算的思想,考虑用一个新的箱子来装货物会发生什么. 显然费用会加上后面的所有货物的总重. \(60\)分的\(O(n^2) ...
- localStorage存、取数组
localStorage存储数组时需要先使用JSON.stringify()转成字符串,取的时候再字符串转数组JSON.parse(). var arr=[1,2,3,4]; localStorage ...
- chrome查看js报错Uncaught SyntaxError: Unexpected string
个人博客原文http://wenhaofan.com/article/20180912123136 js报错,最后发现是$(function(){})这部分()不完整 $(function({ $(& ...
- django学习,captcha图形验证码的使用
很多网站在登录或者注册的时候都有验证码,让你去输入. 刚好有这么一款插件,可以满足这个功能 首先,先pip install django-simple-captcha 然后再setting里添加,如 ...