UOJ #142. 【UER #5】万圣节的南瓜灯 并查集

时间:2022-05-14 21:21:59

#142. 【UER #5】万圣节的南瓜灯

Time Limit: 20 Sec

Memory Limit: 256 MB

题目连接

http://uoj.ac/problem/142

Description

红包是一个心灵手巧的男孩子。今天是万圣节,红包正在家里制作南瓜灯。

这时候一群熊孩子们敲开了红包家的门,他们高呼着“不用给糖,只要捣蛋”的口号把红包的南瓜灯弄坏了。这让红包很难过,于是他打算把这些被弄坏的南瓜灯做成其他的工艺品。

红包把它的南瓜灯划分成了 n×m 的网格,并用 (x,y) 表示第 x 行,第 y 列的格子。两个格子是相邻的当且仅当它们有一条公共边,特殊地, (x,1) 和 (x,m) 红包也视为是相邻的,但是他不把 (1,x) 和 (n,x) 当做是相邻的。

对于一个有 K 个格子被弄坏的南瓜灯,如果它能被制作成工艺品,当且仅当对于任意两个没有被弄坏的格子,都存在且仅存在一条连接它们的简单路径。一条简单路径定义为一个只包含没有被弄坏的格子的序列 A1 至 An ,其中对于任意的 1≤i<n 都有 Ai 和 Ai+1 是相邻的,且每一个格子在序列中至多出现了一次。

现在红包有 T 个南瓜灯,他想让你帮他分别判断每一个南瓜灯能不能被做成工艺品。

Input

第一行一个正整数 T,表示南瓜灯数目。

对于每一个南瓜灯,第一行是三个整数 n,m,K,表示南瓜灯的大小和被弄坏的格子数。

接下来 K 行每行包含两个整数 x,y(1≤x≤n,1≤y≤m),表示第 x 行第 y 列的格子被弄坏了。

数据保证 n,m≥3,0≤K<nm 且不会重复描述一个被弄坏的格子。

Output

对于每一个南瓜灯,输出一行,如果这个南瓜灯能被做成工艺品,那么输出 "Yes",否则输出 "No"。

Sample Input

3
3 3 4
2 1
2 3
3 1
3 3
3 3 5
1 1
1 2
2 1
3 1
3 2
3 3 4
1 1
2 2
2 3
3 3

Sample Output

No
Yes
No

HINT

题意

给你一个网格,然后有些地方是墙,然后问你空出来的地方,是否能够构成一颗树

注意,左右是相连的

题解:

就暴力就好了,注意如果n*m>3e5 是可以直接判断为no的

所以这个可以拿到很多测试点

代码

#include<iostream>
#include<stdio.h>
#include<cstring>
using namespace std;
#define maxn 1005000
int n,m,k,x,y;
int fa[maxn];
int vis[maxn];
int fi(int x)
{
return fa[x]==x?x:fa[x]=fi(fa[x]);
}
int flag = ;
int tot = ;
void uni(int x,int y)
{
int p = fi(x);
int q = fi(y);
if(p==q)
flag=;
if(p!=q)
{
fa[p]=q;
tot++;
}
}
int get(int x,int y)
{
long long p = x*m-m+y;
return p>?:p;
}
int main()
{
int t;scanf("%d",&t);
while(t--)
{
tot = ;
memset(vis,,sizeof(vis));
scanf("%d%d%d",&n,&m,&k);
if(1ll*n*m>){puts("No");for(int i=;i<=k;i++)scanf("%d%d",&x,&y);continue;}
for(int i=;i<=k;i++)
{
scanf("%d%d",&x,&y);
vis[get(x,y)]=;
}
for(int i=;i<=n*m;i++)
fa[i]=i;
flag = ;
for(int i=;i<=n*m;i++)
{
if(vis[i]==)
{
if(i%m==&&!vis[i-m+])
uni(i-m+,i);
if(i%m!=&&!vis[i-])
uni(i-,i);
if(i>m&&!vis[i-m])
uni(i-m,i);
if(flag)break;
}
if(flag)break;
}
if(flag||tot+!=n*m-k)
printf("No\n");
else
puts("Yes");
}
}

UOJ #142. 【UER #5】万圣节的南瓜灯 并查集的更多相关文章

  1. UOJ&lowbar;14&lowbar;【UER &num;1】DZY Loves Graph&lowbar;并查集

    UOJ_14_[UER #1]DZY Loves Graph_并查集 题面:http://uoj.ac/problem/14 考虑只有前两个操作怎么做. 每次删除一定是从后往前删,并且被删的边如果不是 ...

  2. &lbrack;UOJ&num;131&rsqb;&lbrack;BZOJ4199&rsqb;&lbrack;NOI2015&rsqb;品酒大会 后缀数组 &plus; 并查集

    [UOJ#131][BZOJ4199][NOI2015]品酒大会 试题描述 一年一度的“幻影阁夏日品酒大会”隆重开幕了.大会包含品尝和趣味挑战两个环节,分别向优胜者颁发“首席品酒家”和“首席猎手”两个 ...

  3. UOJ 393 【NOI2018】归程——可持久化并查集

    题目:http://uoj.ac/problem/393 题解:https://www.cnblogs.com/HocRiser/p/9368067.html 但过不了 UOJ 的 hack 数据.不 ...

  4. 【uoj&num;142】【UER &num;5】万圣节的南瓜灯 乱搞&plus;并查集

    题目描述 给出一张 $n\times m$ 的网格图,两个格子之间有一条双向边,当且仅当它们相邻,即在网格图中有一条公共边. 特殊地,对于 $1\le x\le n​$ ,$(x,1)​$ 和 $(x ...

  5. 【uoj&num;143】&lbrack;UER &num;5&rsqb;万圣节的数列 构造

    题目描述 给出一个的数列,将其重新排列,使得其等差子序列的数目最小.输出一种可能的排列后的数列. 题解 构造 那天和 EdwardFrog 讨论 bzoj2124 的构造时突然有的灵感,最后发现就是这 ...

  6. UOJ &num;455 &lbrack;UER &num;8&rsqb;雪灾与外卖 &lpar;贪心、模拟费用流&rpar;

    题目链接 http://uoj.ac/contest/47/problem/455 题解 模拟费用流,一个非常神奇的东西. 本题即为WC2019 laofu的讲课中的Problem 8,经典的老鼠进洞 ...

  7. 2019&period;01&period;22 uoj&num;14&period; 【UER &num;1】DZY Loves Graph(并查集)

    传送门 题意简述: 要求支持以下操作: 在a与b之间连一条长度为i的边(i是操作编号):删除当前图中边权最大的k条边:表示撤销第 i−1次操作,保证第1次,第i−1 次不是撤回操作. 要求在每次操作后 ...

  8. &lbrack;UOJ&num;245&rsqb;&lbrack;UER&num;7&rsqb;天路&lpar;近似算法&rpar;

    允许5%的相对误差,意味着我们可以只输出$\log_{1.05} V$种取值并保证答案合法.并且注意到答案随着区间长度而单增,故取值不同的答案区间是$O(\log_{1.05} V)$的. 于是初始x ...

  9. Uoj &num;131&period; 【NOI2015】品酒大会 后缀数组&comma;并查集

    #131. [NOI2015]品酒大会 统计 描述 提交 自定义测试 一年一度的“幻影阁夏日品酒大会”隆重开幕了.大会包含品尝和趣味挑战两个环节,分别向优胜者颁发“首席品酒家”和“首席猎手”两个奖项, ...

随机推荐

  1. CSS3 &commat;keyframes 动画

    CSS3的@keyframes,它可以取代许多网页动画图像,Flash动画,和JAVAScripts. CSS3的动画属性 下面的表格列出了 @keyframes 规则和所有动画属性: 浏览器支持 表 ...

  2. Sharepoint-Hosted App in 2013资料

    一个完整的流程,可参考网址 My First Sharepoint-Hosted App in 2013 部署第一个APP会遇到各种问题,可以参考网址 App development in Share ...

  3. hdu 4057--Rescue the Rabbit&lpar;AC自动机&plus;状压DP&rpar;

    题目链接 Problem Description Dr. X is a biologist, who likes rabbits very much and can do everything for ...

  4. springMVC源码分析--HandlerMapping&lpar;一&rpar;

    HandlerMapping的工作就是为每个请求找到合适的请求找到一个处理器handler,其实现机制简单来说就是维持了一个url到Controller关系的Map结构,其提供的实际功能也是根据req ...

  5. Spark入门到精通--(第九节)环境搭建(Hive搭建)

    上一节搭建完了Hadoop集群,这一节我们来搭建Hive集群,主要是后面的Spark SQL要用到Hive的环境. Hive下载安装 下载Hive 0.13的软件包,可以在百度网盘进行下载.链接: h ...

  6. 年底Android面试整理&lpar;附答案&rpar;

    面试,无非都是问上面这些问题(挺多的 - -!),聘请中高级的安卓开发会往深的去问,并且会问一延伸二.以下我先提出几点重点,是面试官基本必问的问题,请一定要去了解! 基础知识 – 四大组件(生命周期, ...

  7. 每天一个linux命令&lpar;12&rpar;&colon;more命令

    1.命令简介 more (more) 该命令一次显示一屏文本,满屏后停下来,并且在屏幕的底部出现一个提示信息,给出至今己显示的该文件的百分比,方便逐页阅读(file perusal filter fo ...

  8. Echarts 简单报表系列二:折线图

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  9. 【HAOI2013】花卉节

    HA果然是弱省中的弱省…… 原题: ZZ市准备在绿博园举办一次花卉节.Dr.Kong接受到一个任务,要买一批花卉进行布置园林.能投入买花卉的资金只有B元 (1 <= B <= 10^18) ...

  10. js中声明函数的方法

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...