C++ 手写代码:实现并查集完整教程
以下是一个简单的C++并查集实现: ```cpp #include <vector> #include <algorithm> class UnionFind { private: std::vector<int> p, rank; public: UnionFind(int n) : p(n), rank(n, 0) { for(int i = 0; i < n; ++i) p[i] = i; } int find(int x) { return p[x] == x ? x : p[x] = find(p[x]); } void unite(int x, int y) { x = find(x); y = find(y); if(x == y) return; if(rank[x] < rank[y]) std::swap(x, y); p[y] = x; if(rank[x] == rank[y]) ++rank[x]; } bool same(int x, int y) { return find(x) == find(y); } }; ``` 在这个实现中,我们使用了两个向量,`p`和`rank`。`p`用于存储每个元素的父节点,`rank`用于存储每个树的大小。`find`函数用于查找一个元素的根节点,`unite`函数用于合并两个树,`same`函数用于判断两个元素是否在同一个树中。 ######[AI写代码神器 | 274点数解答 | 2023-11-09 00:48:48]
- Python 实现球类:精准计算半径、表面积与体积,附输入验证与异常处理!(阿里通义 | 261点数解答 | 2024-11-28 21:19:39)345
- 从0到1:Go语言快速入门超全教程(阿里通义 | 565点数解答 | 2023-12-07 23:37:28)299
- C++ 实现我的世界基岩版:从简单框架到开发要点揭秘(字节豆包 | 182点数解答 | 2025-02-22 15:53:11)197
- C++ 实现完整斗地主:含洗牌、发牌与手牌展示,可按需扩展!(字节豆包 | 1028点数解答 | 2026-01-10 08:02:37)37
- 51 单片机:定时器 0 实现 8 个 LED 循环点亮,附代码及优化建议(字节豆包 | 1193点数解答 | 2024-12-27 15:10:29)314
- 用 JS 中 for 循环实现 1 到 100 相加并输出结果到页面的完整代码 ( | 240点数解答 | 2024-05-20 22:11:29)465
- 用 JS 的 while 循环实现 1 到 100 相加并输出到页面的代码揭秘( | 47点数解答 | 2024-05-20 22:16:48)356
- iOS开发:手把手教你完整实现代理模式,含声明与实现步骤!(阿里通义 | 268点数解答 | 2023-11-08 00:39:55)254
- JavaScript 开发:用 Animation 实现自定义动画的简易教程 (阿里通义 | 333点数解答 | 2023-11-09 01:50:07)245
- Vue.js 与 Matter.js 碰撞:轻松实现物理模拟全攻略 (讯飞星火 | 522点数解答 | 2024-05-29 22:26:06)432
- JS实现移动端网页快捷键创建方式及注意事项(阿里通义 | 284点数解答 | 2024-06-05 19:02:59)267
- 车载系统 UML 类图设计:涵盖 Car、Engine、娱乐系统等的完整类定义与关系解析 (字节豆包 | 760点数解答 | 2024-08-15 22:51:04)312