并查集,find函数的压缩路径,Union函数的小树合并大树

#include<stdio.h>

#define maxSize 10

//用森林的双亲表示法的思想,表示并查集

int SmaxSize;

//初始化,将每个元素的前驱下标设置为-1

void initial(int s\[\]){

for(int i=0;i<maxSize;i++){

si=-1;

}

}

//实现"查"的操作,查这个元素所属的根节点的下标

int find(int s\[\],int k){

int root=k;

while(sroot>=0) root=sroot;//找到根节点

//压缩路径,将k到根节点的所有结点都变为根节点的直接后继

while(k!=root){

int t=sk;//指向k的父节点

sk=root;

k=t;

}

return root;

}

//实现"并"的操作,小树并到大树里面

void Union(int s\[\],int root1,int root2){

if(root1==root2){

return;

}

//确保root1和root2是根节点

if(sroot1>=0){

root1=find(s,root1);

}

if(sroot2>=0){

root2=find(s,root2);

}

//小树合并到大树里面

if(sroot1>sroot2){

sroot2+=sroot1;//更新结点个数,每个根节点的数组值为连接的结点个数

sroot1=root2;//合并

}else{

sroot1+=sroot2;

sroot2=root1;

}

}

int main(){

//自己的测试数据

S0=-1;S1=0;S2=-1;S3=-1;S4=1;S5=1;S6=2;S7=3;S8=3;S9=3;S10=4;

printf("5的根节点是%d\n",find(S,5));

printf("6的根节点是%d\n",find(S,6));

//合并

Union(S,0,2);

printf("5的根节点是%d\n",find(S,5));

printf("6的根节点是%d\n",find(S,6));

return 0;

}

相关推荐
8Qi86 小时前
回文子串(Palindromic Substrings)—— 题解
算法·leetcode·职场和发展·动态规划
小宋加油啊10 小时前
机械臂抓取物体 PVN3D算法调研学习
学习·算法·3d
lqqjuly10 小时前
前沿算法深度解析(一)
算法
小欣加油11 小时前
leetcode1926 迷宫中离入口最近的出口
数据结构·c++·算法·leetcode·职场和发展
happymaker062613 小时前
LeetCodeHot100——42.接雨水
算法
阿正的梦工坊14 小时前
【Rust】07-错误处理:Option、Result 与 ? 运算符
开发语言·算法·rust
烬羽14 小时前
从零理解树与二叉树:用 JS 带你手撕遍历和递归
javascript·数据结构
YHL14 小时前
🚀从零理解树与二叉树 —— 概念、实现与遍历
前端·javascript·数据结构
JieE21214 小时前
JS 到底有多少种数据类型?从ECMA规范到内存本质,一文彻底搞懂
javascript·数据结构·面试