当前位置: 首页 > news >正文

高邮做网站大英哪里有做网站的

高邮做网站,大英哪里有做网站的,仿淘宝网站,桂林微信网站合并集合 一共有n个数,编号是1~n,最开始每个数各自在一个集合中。 现在要进行m个操作,操作共有2种: 1.“M a b”,将编号为a和b的两个数的所在的集合合并,如果两个数已经在同一个集合中则忽略这个操作 2.“…

合并集合

一共有n个数,编号是1~n,最开始每个数各自在一个集合中。
现在要进行m个操作,操作共有2种:
1.“M a b”,将编号为a和b的两个数的所在的集合合并,如果两个数已经在同一个集合中则忽略这个操作
2.“Q a b”,询问编号为a和b的两个数是否在同一个集合中

输入格式

第一行输入整数n和m
接下来m行,每行包含一个操作指令,指令为"M a b"或"Q a b"的一种

输出格式

对于每个询问指令"Q a b",都要输出一个结果,如果a和b在同一集合内则输出"Yes",否则输出"No"
每个结果占一行

数据范围

1 ≤ n , m ≤ 1 0 5 1\le n,m\le 10^5 1n,m105

输入样例

4 5
M 1 2
M 3 4
Q 1 2
Q 1 3
Q 3 4

输出样例

Yes
No
Yes

问题分析

并查集(DSU,Disjoint Set Union)
1.将两个集合合并
2.询问两个元素是否在一个集合中
基本原理:每个集合用一棵树来表示。树根的编号就是整个集合的编号。每个结点存储它的父结点,p[x]表示x的父结点

问题1:如何判断树根
if(p[x] == x)
问题2:如何求x的集合编号
while(p[x] != x) x = p[x];
问题3:如何合并两个集合
p[x]x 的集合编号,p[y]y 的集合编号。p[x] = y

优化:路径压缩

AC代码

#include<iostream>
using namespace std;const int N = 1e5 + 10;int n, m;
int p[N];int find(int x) {	// 返回 x 的祖宗结点 + 路径压缩if(p[x] != x) p[x] = find(p[x]);return p[x];
}int main() {scanf("%d%d", &n, &m);for(int i = 1; i <= n; i++) p[i] = i;while(m--) {char op[2];int a, b;scanf("%s%d%d", op, &a, &b);if(op[0] == 'M') p[find(a)] = find(b);else {if(find(a) == find(b)) puts("Yes");else puts("No");}}return 0;
}
http://www.yayakq.cn/news/166689/

相关文章:

  • 营销型网站建设特点凡科网站是什么做的
  • 福州做网站建设公司希爱力
  • 东莞网站建设平台企业网站建设算什么费用
  • 网站排名优化原理做网站建设的公司有哪些方面
  • 西安哪里做网站最大中学生旅游网站开发的论文怎么写
  • 网站建设专业可行性分析wordpress 访客统计
  • 长沙注册公司核名网站烟台做网站哪家做的好
  • 贵州公司网站建设比选公示郑州专门做喷绘安装的网站
  • 公司建设网站申请信用卡绍兴企业网站建站模板
  • 彩票网站net网站开发找那家做3d人物模型素材下载网站
  • 2014网站设计风格承德在线招聘
  • 公司主页和公司网站网站建设收费流程
  • 站长工具网站推广律师怎么做网站
  • 专业网站设计第三方手机网站开发设计
  • 在什么网站上可以做免费广告wordpress自定义搜索文件
  • 佛山seo整站优化免费咨询英文
  • wordpress中国网站排名wordpress模板wiki
  • 做淘宝客的的网站有什么要求wordpress 本地加速
  • 毕业设计代做网站php中企动力建站怎么样
  • 电影网站html代码百度网站诚信认证
  • 网站建设初验申请表wordpress 评论模版
  • 推广网站广告有哪些你的安全设置不允许网站
  • 自助微信网站设计标识设计图片
  • 泰州免费网站建站模板网站qq聊天代码
  • 手机网站加百度商桥中企动力是外包公司吗
  • 承德网站建设服务如何买网站
  • 吉林做网站的公司公司网站怎么建立优化体系
  • html网站开发中的应用梵客家装电话
  • 惠州做网站电话装修网站排名前十名
  • 联盟营销网站有哪些wordpress还原安装