首页 > 其他分享 >基础代码-维护图的连通性

基础代码-维护图的连通性

时间:2022-11-22 18:34:57浏览次数:54  
标签:fax 连通性 mat int 代码 flag 维护 include find


问题 D: 维护图的连通性

时间限制: 1 Sec  内存限制: 128 MB

题目描述


给定一个无向图 G,写一个程序处理以下两种操作:

1. 删去一条边 (u, v)

2. 询问两点 u,v是否连通  

输入

输入文件的第一行包含三个整数 n,m,q,依次代表图的顶点数、边数、 询问的个数。

接下来 m 行,每行两个整数 u,v,描述图中的一条边(u, v)。接下来q 行,每行三个整数t,u,v,描述一个操作。若t = 1 则操作代表删去边 (u, v),否则操作代表询问点u 和 v 是否连通。数据保证删除的边一定存 在。 

 

输出

对于每个询问操作输出一行字符串 “Yes”(连通)或者“No”(不连通)。  

样例输入

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

样例输出

Yes
No
Yes


提示

对于所有的数据, n ≤ 1000,m ≤ 100000, q≤ 100000,可能存在重边。 

正难则反。先将图构建好后,将要删除的边先删去,然后从最后一个询问开始处理,若t[i]=1则将这条边连上,若t[i]=2则判断u与v是否连通。用并查集维护连通性。

Code:

#include <cstdio>
#include <iostream>
#include <cstring>
#include <algorithm>
#include <cmath>
#define M 101000
#define N 1100
#define Q 101000
using namespace std;
int u[M],v[M],t[Q],x[Q],y[Q],f[N],mat[N][N],flag[Q];
inline int find(int x)
{
if(f[x]!=x) f[x]=find(f[x]);
return f[x];
}
inline void unionn(int x,int y)
{
int fax=find(x),fay=find(y);
if(fax!=fay) f[fax]=fay;
}
int main()
{
int n,m,q;
scanf("%d%d%d",&n,&m,&q);
for(int i=1;i<=m;i++)
{
scanf("%d%d",&u[i],&v[i]);
mat[u[i]][v[i]]++;
mat[v[i]][u[i]]++;
}
for(int i=1;i<=q;i++)
{
scanf("%d%d%d",&t[i],&x[i],&y[i]);
if(t[i]==1){mat[x[i]][y[i]]--;mat[y[i]][x[i]]--;}
}
for(int i=1;i<=n;i++) f[i]=i;
for(int i=1;i<=m;i++)
if(mat[x[i]][y[i]])
{
int fx=find(x[i]),fy=find(y[i]);
if(fx!=fy) f[fx]=fy;
}
for(int i=q;i;i--)
{
if(t[i]==1){unionn(x[i],y[i]);flag[i]=-1;}
else{
int fax=find(x[i]),fay=find(y[i]);
if(fax==fay) flag[i]=1;else flag[i]=0;
}
}
for(int i=1;i<=q;i++)
if(!flag[i]) puts("No");
else if(flag[i]==1) puts("Yes");
return 0;
}

标签:fax,连通性,mat,int,代码,flag,维护,include,find
From: https://blog.51cto.com/u_15888102/5878321

相关文章

  • 基础代码-维护集合
    问题C:维护集合时间限制:1Sec  内存限制:512MB题目描述维护一个字符串集合:初始为空,依次处理一些插入操作,并在插入之后输出该字符串在集合中出现的次数。......
  • 基础代码-计算后缀表达式
    问题E:计算后缀表达式时间限制:1Sec  内存限制:128MB题目描述后缀表达式是将运算符置于两个运算对象之后的一种表达方法,例如“3+4”用写成后缀表达式后就......
  • 基础代码-线段
    问题B:线段时间限制:1Sec  内存限制:128MB题目描述1.询问+LR增加一条线段[L,R],你的程序应该输出有多少条线段被该线段包含(非严格)。2.询问-L......
  • javascript-代码随想录训练营day6
    242.有效的字母异位词题目链接:https://leetcode.cn/problems/valid-anagram/题目描述:给定两个字符串s和t,编写一个函数来判断t是否是s的字母异位词。注意:若s......
  • 使用MSIL采用Emit方式实现C#的代码生成与注入常用代码
    本文主要使用微软提供的一套C#的API函数,通过这些API函数,可以对已经编译过的.Net体系生成的EXE,DLL文件进行修改,而不是修改源码编译的方式,来完成新功能的加入、或者原有功......
  • ECharts – 饼状图图代码实例及其注释详解
    mytextStyle={color:"#333",//文字颜色fontStyle:"normal",//italic斜体oblique倾斜fontWeight:"normal",//文字粗细boldbolderl......
  • ECharts – 折线图代码实例及注释
    mytextStyle={color:"#333",//文字颜色fontStyle:"normal",//italic斜体oblique倾斜fontWeight:"normal",//文字粗细boldbolderl......
  • ECharts – 柱形图代码实例及其注释详解
    mytextStyle={color:"#333",//文字颜色fontStyle:"normal",//italic斜体oblique倾斜fontWeight:"normal",//文字粗细boldbolderl......
  • Java实现网络爬虫 案例代码
    Java实现网络爬虫案例代码需求说明搭建开发环境,实现《三国演义》全文保存在本地 步骤分析访问网址:http://www.shicimingju.com/book/sanguoyanyi.html分析网站URL......
  • HX学习之常用代码块
    查看内建的代码块,点击菜单-工具-代码块设置,选择要查看的语言的代码块。通用js代码块iff:简单ifforr:for循环结构体fori:for循环结构体并包含ifunn:函数funa:匿名函数......