POJ1182--带权并查集

带权并查集就是除了维护一个fa数组以外,维护一个rank数组,有两层含义,一个是路径压缩时边的权值,,再一个是当前点与根节点的相对关系。这个题很明显考察的是

根节点与当前节点的一种相对关系,让rank【x】 = 0 ,1,2表示A,B,C三个种类的动物,在刚开始的时候,所有的动物的rank值都是0,表示还没有给他们安排关系,随

着语句的输入,1xy表示把x,y置为相同值,2xy表示rank【x】 + 1 = rank【y】,然而在这里并不是直接改变y的rank的值,而是改变y所在的根结点的rank值,因为一旦x,y确

立了关系,和y在一个集合内的动物都与x建立了关系,这样只有改变根节点的rank才能保证每一个动物的rank都会被更新到,因为在x所在的集合和y所在的集合没有建立关系

之前,x,y的关系可以是任意的。

如果输入1xy,首先看x,y是否在一个集合内,如果是那麽x,y之间是一种绝对的关系,可以通过rank【x】和rank【y】的大小来判断语句的正确性,如果不是那麽x,y之间就没有

确定的关系,那么这句话就是对的,修改rank【y】所在集合的根结点的rank值,

输入2xy时和输入1xy时同理。

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<vector>
#include<map>
#define N 100005
#define lc rt<<1
#define rc rt<<1|1
#define INF 0x3f3f3f3f
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
const int maxn = 5e4 + 10;int n,k;
int d,x,y;
int fa[maxn];
int rank[maxn];int find(int x)
{if(fa[x] == x)return x;int p = find(fa[x]);rank[x] = (rank[fa[x]] + rank[x])%3;return fa[x] = p;
}int main()
{//freopen("in","r",stdin);int cnt = 0;scanf("%d%d",&n,&k);for(int i = 0; i < n; ++i) fa[i] = i;memset(rank,0,sizeof(rank));for(int i = 0; i < k; ++i){scanf("%d%d%d",&d,&x,&y);if(x > n||y > n||(d == 2&&x == y)) {cnt++;continue;}int s1 = find(x),s2 = find(y);//求根节点if(d == 1){if(s1 == s2){if(rank[x] != rank[y]) cnt++;}else {rank[s2] = (rank[x] - rank[y] + 3)%3;//更新y的根结点,注意不要写错s2;fa[s2] = s1;//建立x集合与y集合的关系;}}else if(d == 2){if(s1 == s2) {if((rank[x] + 1)%3 != rank[y]) cnt++;}else {rank[s2] = (rank[x] + 1 - rank[y] + 3)%3;//同上fa[s2] = s1;}}//printf("%d %d\n",i,cnt);
     }printf("%d\n",cnt);
}

 

转载于:https://www.cnblogs.com/Norlan/p/4888413.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/404892.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Qt MQTT使用

一、创建对象并绑定信号槽 m_client new QMqttClient(this); connect(m_client, &QMqttClient::stateChanged, this, &MainWindow::updateLogStateChange); connect(m_client, &QMqttClient::disconnected, this, &MainWindow::brokerDisconnected); connect…

20231222给NanoPC-T4(RK3399)开发板的适配Android11的挖掘机方案并跑通AP6398SV

20231222给NanoPC-T4(RK3399)开发板的适配Android11的挖掘机方案并跑通AP6398SV 2023/12/22 7:54 简略步骤&#xff1a;rootrootrootroot-X99-Turbo:~/3TB$ cat Android11.0.tar.bz2.a* > Android11.0.tar.bz2 rootrootrootroot-X99-Turbo:~/3TB$ tar jxvf Android11.0.tar.…

Web服务器捉虫速记

一服务器疑似被挂马&#xff0c;现象是从百度搜该站点&#xff0c;出来的结果大部分为色情网站。 马上登录服务器&#xff08;半夜好困啊&#xff09;。执行如下的步骤&#xff1a;<!--[if !supportLists]-->1、 <!--[endif]-->检查系统帐号&#xff0c;看有没有异…

KEIL5 编译器导致的程序异常

STM32F407写程序过程中发现了一个KEIL5 ARM编译器导致的BUG&#xff0c;记录如下。 源代码比较简单&#xff0c;分别打印两个标志量的值&#xff0c;采用了volatile 声明&#xff0c;避免被优化。 代码功能不用多说&#xff0c;看一下输出结果&#xff1a; 两个标志量都被编译…

C++笔记(1)explicit构造函数

From: http://www.cnblogs.com/cutepig/archive/2009/01/14/1375917.html 按照默认规定&#xff0c;只有一个参数的构造函数也定义了一个隐式转换&#xff0c;将该构造函数对应数据类型的数据转换为该类对象&#xff0c;如下面所示&#xff1a;class String {String ( const …

高级软件工程课程第一次作业的小结

成果&#xff1a; 1&#xff09;各位同学按要求建立了自己博客&#xff0c;完善并反馈的相关信息 2&#xff09;对各自本科设计进行了分析&#xff0c;有的同学也写得比较详细&#xff0c;如曾秀、李文华、吴文兵等 存在的问题&#xff1a; 1&#xff09;对软件工程的认识较基础…

Windows中添加svnserve作为系统服务

安装subversion后&#xff0c;其安装目录中有svnserve程序。 采用windows系统的sc命令将其添加为自动启动的系统服务&#xff1a; sc create MySVNServer binpath "D:\Program Files\Subversion\bin\svnserve.exe --service -r G:\Repositories" displayname "S…

[react] 在React中如何引入图片?哪种方式更好?

[react] 在React中如何引入图片&#xff1f;哪种方式更好&#xff1f; 第一种导入&#xff1a; import Img from "./images/1.png" 第二种直接获取图片&#xff1a; <img src{require("./images/1.png")} alt""/> 个人简介 我是歌谣&a…

STM32F407控制AD7606 采用HAL库的TIM和SPI

前言 本文介绍基于STM32F407的AD7606 8通道同步采集控制方式&#xff0c;总体思路&#xff1a;PWM驱动AD7606完成模数转换&#xff0c;AD7606转换完成后其BUSY引脚给出下降沿&#xff0c;STM32捕获外部中断并在中断服务程序中调用SPI串口读取AD7606数据&#xff0c;工程采用cu…

(转)二分图最大匹配的König定理及其证明

出处:http://www.matrix67.com/blog/archives/116 二分图最大匹配的Knig定理及其证明 如果你看不清楚第二个字母&#xff0c;下面有一个大号字体版本&#xff1a;二分图最大匹配的Knig定理及其证明 本文将是这一系列里最短的一篇&#xff0c;因为我只打算把Knig定理证了&…

如何使用struts2对集合参数进行验证

上一节介绍了struts2可以支持批量表单参数提交&#xff0c;那么提交到后台时如何利用strust2的validation框架对这个集合做验证&#xff1f; struts2提供了一个vistor校验器&#xff0c;可以实现这个需求 还是采用上一节中批量添加书籍的例子 1.jsp文件 <% taglib prefix&qu…

关于__attribute__ ((packed))

#include <iostream>using namespace std;typedef struct {unsigned char ver;unsigned char cmd;unsigned short id;unsigned short retcode; }__attribute__ ((packed)) ACKPACK_CMD;struct my {char ch; int a; }__attribute__ ((packed)); // 取消结构在编译过程中…

[react] React中验证props的目的是什么?

[react] React中验证props的目的是什么&#xff1f; 对属性进行强检验&#xff0c;避免运行时报错 我是歌谣&#xff0c;欢迎和大家一起交流前后端知识。放弃很容易&#xff0c; 但坚持一定很酷。欢迎大家一起讨论 主目录 与歌谣一起通关前端面试题

[Axure教程]0001.新手入门基础

Axure RP是一个专业的快速原型设计工具。Axure&#xff08;发音&#xff1a;Ack-sure&#xff09;&#xff0c;代表美国Axure公司&#xff1b;RP则是Rapid Prototyping&#xff08;快速原型&#xff09;的缩写。Axure RP已被一些大公司采用。Axure RP的使用者主要包括商业分析师…

typedef和#define的作用域问题

#include <iostream>using namespace std;class A { #define MAX 5 // 宏定义是全局的&#xff0c;因为在预编译时就替换掉了public:typedef unsigned long ULONG; // 作用域局限在这个类中, 且有修饰符private:int _n;ULONG _age;public:A(int n, ULONG age);void …

【评论】GNU/Linux下有多少是GNU的?

导读&#xff1a;一个葡萄牙的学生写了一篇文章 《How much GNU is there in GNU/Linux?》由酷壳网的陈皓整理编译为《GNU/Linux下有多少是GNU的》。这篇文章主要分布了今年4月份的Ubuntu Natty的Linux分发包。其主要是用代码行来做的分析&#xff0c;用两个饼图对比分析。内容…

[react] 在React中怎么使用字体图标?

[react] 在React中怎么使用字体图标&#xff1f; 1、npm install --save react-fontawesome 2、npm install font-awesome 3、import ‘font-awesome/less/font-awesome.less’; 4、import ‘react-fontawesome’; 个人简介 我是歌谣&#xff0c;欢迎和大家一起交流前后端知…