并查集,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;

}

相关推荐
vibecoding日记6 小时前
双非如何快速入职字节等大厂大模型?真实案例分析:推理优化和投机解码
算法·求职·大模型工程师
yszaygr21389 小时前
Verilog参数化游程编码RLE模块
算法
望易9 小时前
刚设计的大模型架构-双域耦合认知框架
算法·架构
复杂网络13 小时前
多个 Claude Code 与多个 Codex 协同工作:设计与实现方案
算法
HjhIron1 天前
面试常客:字符串算法从入门到进阶
算法·面试
吴佳浩1 天前
DeepSeek DSpark:Confidence-Scheduled Speculative Decoding 技术解析
人工智能·算法·deepseek
触底反弹1 天前
🧠 搞懂 Token,才算真正入门大模型——从分词原理到 Embedding 语义实战
javascript·人工智能·算法
vivo互联网技术1 天前
ICLR 2026 | 基于后验采样的图像恢复方法LearnIR:人脸去阴影、去雾
人工智能·算法·aigc
浮生望2 天前
JS字符串与回文算法:从包装类到双指针的面试进阶之路
javascript·算法
黄敬峰2 天前
面试必刷:从JS底层包装类到双指针,彻底搞懂字符串与回文算法
算法