数据结构——并查集

1.并查集的定义

并查集其实也是一种树形结构,在使用中通常用森林的方式来表示

并查集的逻辑结构其实就是集合

并查集一般可以通过双亲写法(顺序结构)来完成,即通过一个数组存储父亲结点的下标

int s[10005];
int main()
{
    for(int i=1; i<=n; i++)
    {
        s[i]=-1;
//为什么一开始都归属于-1呢,我们要从定义入手,我们的数组存储的是父亲结点的下标,若从-1开始,
//可以意味着,他们一开始都是单独的元素,方便后续的查和并操作
    }
}

2.并查集能进行的操作

1.查:寻找一个元素归属于哪个集合或者说判断两个元素是否同属于一            个集合

int cha(int x)
{
    while(s[x]>=0)//当指针不为-1时就会一直向前搜索,直到搜索出根结点
        x=s[x];
    return x;//返回根结点的下标
}

2.并:将两个子树并在一起,通常是将小子树并在大子树上面

void bing(int root1,int root2)
{
    if(root1==root2) return;//传进来两个根节点一样的本来就是本身,不用合并,直接返回就好
    s[root2]=root1;//将子树2的指针指向子树1的下标
}

3.并查集相关例题

第一题:并查集

 题解,这题也是十分简单,合并操作就是用上述的并,判断是否在一个集合就要用查了,如果相等,则证明在一个集合里

看AC代码:

#include<bits/stdc++.h>
using namespace std;
int n,m;

int a[20005];//定义一个双亲写法的数
int z,x,y;
int cha(int x)//查
{
    while(a[x]>=0)
    {
        x=a[x];
    }
    return x;
}
void bing(int root1,int root2)//并
{
    if(root1==root2)
        return;
    a[root2]=root1;
}
int main()
{
    scanf("%d%d",&n,&m);
    for(int i=1;i<=n;i++)
    {
        a[i]=-1;
    }
    for(int i=0;i<m;i++)
    {
        scanf("%d%d%d",&z,&x,&y);
        if(z==1)
        {
            bing(cha(x),cha(y));//合并树的时候合并的是根
        }
        if(z==2)
        {
            int p=cha(x);
            int q=cha(y);
            if(p==q)
                printf("Y\n");
            else
                printf("N\n");
        }
    }
    return 0;
}

第二题:亲戚

 题解:这题也是很简单,判断是否是亲戚,只需要判断是否在一个结点就可以,因此上面那题差不多

AC代码:

#include<bits/stdc++.h>
using namespace std;
int n,m,p;
int s[10005];
int x,y;
int cha(int x)
{
    while(s[x]>=0)
        x=s[x];
    return x;
}
void bing(int root1,int root2)
{
    if(root1==root2) return;
    s[root2]=root1;
}
int main()
{
    scanf("%d%d%d",&n,&m,&p);
    for(int i=0; i<m; i++)//    for(int i=1; i<=n; i++)
    {
        s[i]=-1;
    }

    {
        scanf("%d%d",&x,&y);
        bing(cha(x),cha(y));
    }
    int r,t;
    for(int i=0; i<p; i++)
    {
        scanf("%d%d",&r,&t);
        int te=cha(r);
        int re=cha(t);
        if(te==re)
            printf("Yes\n");
        else
            printf("No\n");
    }
    return 0;
}

第三题:朋友

 题解,我们只需要放置两个数组,判断那边的子树的节点更少就可以

AC代码

#include<bits/stdc++.h>
using namespace std;
int n,m,p,q;
int x,y,z,t;
int a[10005];
int b[10005];

int cha(int x,int s[])
{
    while(s[x]>=0)
        x=s[x];
    return x;
}
void bing(int root1,int root2,int z[])//唯一要处理的就是尽量往小明和小红身上连接子树
{
    if(root1==root2)
        return ;
    if(root1==1)
    {
        z[root2]=root1;
    }
    else if(root2==1)
    {
        z[root1]=root2;
    }
    else
    {
        z[root2]=root1;
    }
}
int main()
{
    scanf("%d%d%d%d",&n,&m,&p,&q);
    for(int i=1; i<=n; i++)
    {
        a[i]=-1;
    }
    for(int i=1; i<=m; i++)
    {
        b[i]=-1;
    }
    for(int i=0; i<p; i++)
    {
        scanf("%d%d",&x,&y);
        bing(cha(x,a),cha(y,a),a);
    }
    for(int i=0; i<q; i++)
    {
        scanf("%d%d",&z,&t);
        bing(cha(-z,b),cha(-t,b),b);
    }
    int sum1=0,sum2=0;
    for(int i=1; i<=n; i++)
    {
        if(cha(i,a)==1)
            sum1++;
    }
    for(int i=1; i<=m; i++)
    {
        if(cha(i,b)==1)
        {
            sum2++;
        }
    }
    printf("%d\n",min(sum1,sum2));
    return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

原来服务器这么有用-使用轻量应用服务器搭建专属自己PDF处理工具

原来服务器这么有用-使用轻量应用服务器搭建专属自己PDF处理工具 1、前言 PDF文件是日常办公中经常使用的一种文档格式。最近&#xff0c;青阳面临一个问题&#xff1a;某公司发送过来的文件需要我们进行印章流程&#xff0c;但由于该公司系统在电子文件加盖电子公章后会自动…

万户 ezOFFICE wpsservlet SQL注入漏洞复现

0x01 产品简介 万户OA ezoffice是万户网络协同办公产品多年来一直将主要精力致力于中高端市场的一款OA协同办公软件产品,统一的基础管理平台,实现用户数据统一管理、权限统一分配、身份统一认证。统一规划门户网站群和协同办公平台,将外网信息维护、客户服务、互动交流和日…

10V单通道负载开关

概述 EM5220是一款单通道负载开关&#xff0c;具有可编程上升时间和集成输出放电控制。该设备包含一个P沟道NOSFET&#xff0c;可以通过输入进行操作电压范围为4.5V至10V。开关由接通和断开低电平逻辑输入控制&#xff0c;其能够与GPIO信号接口。设备的可编程上升时间可以减少…

代码随想录刷题笔记-Day15

1. 完全二叉树的的节点个数 222. 完全二叉树的节点个数https://leetcode.cn/problems/count-complete-tree-nodes/ 给你一棵 完全二叉树 的根节点 root &#xff0c;求出该树的节点个数。 完全二叉树 的定义如下&#xff1a;在完全二叉树中&#xff0c;除了最底层节点可能没…

课时7:shell基础_shell简介

1.3.1 shell简介 学习目标 这一节&#xff0c;我们从 运维、shell语言、小结 三个方面来学习。 运维 简介 运维是什么&#xff1f;所谓的运维&#xff0c;其实就是公司的内部项目当中的一个技术岗位而已&#xff0c;它主要做的是项目的维护性工作。它所涉及的内容范围非常…

Redhat 8.4 一键安装 Oracle 11GR2 单机版

Oracle 一键安装脚本&#xff0c;演示 Redhat 8.4 一键安装 Oracle 11GR2 单机版过程&#xff08;全程无需人工干预&#xff09;&#xff1a;&#xff08;脚本包括 ORALCE PSU/OJVM 等补丁自动安装&#xff09; ⭐️ 脚本下载地址&#xff1a;Shell脚本安装Oracle数据库 脚本…

插接母线温度在线监测系统研究与应用

摘要&#xff1a;低压封闭式插接母线是供配电设施的关键部件&#xff0c;安装在生产车间内部高空&#xff0c;不易保养和维护&#xff0c;在安装不良或保养不当时易发生故障。插接点温度的异常变化与母线故障的发生有着密切的关系&#xff0c;以汽车整车制造工厂为例&#xff0…

Unity 策略模式(实例详解)

文章目录 简介示例1&#xff1a;角色攻击行为示例2&#xff1a;游戏内购折扣策略示例3&#xff1a;NPC寻路策略示例4&#xff1a;动画过渡策略示例5&#xff1a;敌人AI决策策略 简介 在Unity中使用策略模式&#xff0c;我们可以将不同的行为或算法封装成独立的类&#xff08;策…

SpringMVC 自动配置

SpringMVC 自动配置 一、WebMvcAutoConfiguration&#xff08;SpringMVC自动配置&#xff09;二、DisPatcherServletAutoConfiguration.class&#xff08;中央调度器自动配置&#xff09;三、WebMvcConfigurationSupport&#xff08;SpringMVC组件配置类&#xff09;四、Servle…

iOS 17.4 苹果公司正在加倍投入人工智能

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…

网络隔离场景下访问 Pod 网络

接着上文 VPC网络架构下的网络上数据采集 介绍 考虑一个监控系统&#xff0c;它的数据采集 Agent 是以 daemonset 形式运行在物理机上的&#xff0c;它需要采集 Pod 的各种监控信息。现在很流行的一个监控信息是通过 Prometheus 提供指标信息。 一般来说&#xff0c;daemonset …

低功耗蓝牙(BLE) 和 经典蓝牙(SPP) 的区别

低功耗蓝牙(BLE) vs 经典蓝牙(SPP) 区别项低功耗蓝牙(BLE)经典蓝牙(SPP 串行端口协议)蓝牙版本蓝牙版本 > 4.0&#xff0c;又称蓝牙低功耗、蓝牙智能经典蓝牙2.0 或更早版本&#xff0c;经典配对模式在两台蓝牙设备之间建立虚拟串口数据连接&#xff0c;提供一种简单而直接…

06.VLAN、Trunk和Hybrid配置

文章目录 一. 初识VLAN1.1. VLAN概述1.2. VLAN的优势1.3. VLAN的帧格式1.4. 接口链路类型1.5. 默认VLAN1.6. VLAN划分方式 二. 实验题2.1. 实验1&#xff1a;划分VLAN2.1.1. 实验目的2.1.2. 实验拓扑图2.1.3. 实验步骤&#xff08;1&#xff09;配置PC机的IP地址&#xff08;2&…

stable diffusion学习笔记——文生图(二)

LORA和Embeddings都可以对画面内容进行调整。目前LORA主要用来定义画面特征&#xff0c;如具体的人物&#xff0c;衣物&#xff0c;画风等。Embeddings目前主要用于反面提示词中&#xff0c;用来避免错误的画面表现。 LORA lora的全称为&#xff1a;低秩适应模型。lora的基本…

05. 交换机的基本配置

文章目录 一. 初识交换机1.1. 交换机的概述1.2. Ethernet_ll格式1.3. MAC分类1.4. 冲突域1.5. 广播域1.6. 交换机的原理1.7. 交换机的3种转发行为 二. 初识ARP2.1. ARP概述2.2. ARP报文格式2.3. ARP的分类2.4. 免费ARP的作用 三. 实验专题3.1. 实验1&#xff1a;交换机的基本原…

常用芯片学习——AMS1117芯片

AMS1117 1A 低压差线性稳压器 使用说明 AMS1117 是一款低压差线性稳压电路&#xff0c;该电路输出电流能力为1A。该系列电路包含固定输出电压版本和可调输出电压版本&#xff0c;其输出电压精度为士1.5%。为了保证芯片和电源系统的稳定性&#xff0c;XBLWAMS1117 内置热保护和…

Nulls: Nothing to Worry About

本文是文章Nulls: Nothing to Worry About的翻译笔记。 避免三值逻辑出现问题。 ISO SQL 标准中的NULL可以是任何东西&#xff0c;但不是一个值。 NULL是指示完全缺乏值的标记。 它们会导致三值逻辑&#xff0c;使用起来很混乱&#xff0c;而且这种混乱常常导致粗心的人编写返…

20240126收获

el-table比较常见的需要跳转column的场景&#xff0c;目前遇到三种&#xff0c;一种是前面列变成序号&#xff0c;用的是typeindex和&#xff1a;index来设置索引&#xff0c;第二种是变成多选&#xff0c;用的是typeselect和在table上加上select-change事件&#xff0c;第三种…

指针操作一维字符型数组和及回调函数------努力学习嵌入式的第十四天!今天的内容让人脑瓜子嗡嗡的 着重复习

总结 1.快速排序 注意&#xff1a; 第二三步并不能反过来 要想降序排列只需要加将比较的符号换一下 2.指针操作一维字符型数组 &#xff08;const&#xff09; char *s "hello"; *sH; //错误 char s[]"hello"; s[0] B char *strncpy(char *d…

掌握 Android JNI 基础

写在前面 最近在看一些底层源码&#xff0c;发现 JNI 这块还是有必要系统的看一下&#xff0c;索性就写一写博客&#xff0c;加深加深印象&#x1f37b; 本文重点聊一聊一些干货&#xff0c;避免长篇大论 JNI 概述 JNI 是什么&#xff1f; 定义&#xff1a;Java Native In…
最新文章