🕸️ 并查集专题:从连通性开始(入门必刷 3 题)
并查集(Disjoint Set Union)是处理连通性问题的高效工具。为了帮助你由浅入深地掌握这一算法,以下精选了 HDU OJ 上最经典、最适合入门的 3 道题目。
1️⃣ 【入门必刷】HDU 1232 - 畅通工程
- 🔗 题目网址: HDU 1232 | 畅通工程
- 💡 推荐理由: 并查集的"教科书"级别题目。以修路为背景,直观地展示了如何求取图中独立集合的数量。
- 🧠 核心逻辑:
- 初始状态下有 N N N 个独立的集合。
- 每当成功合并(Union)两个不同集合的城镇时,集合总数减 1。
- 最终答案:
剩余集合数 - 1。
2️⃣ 【基础巩固】HDU 1213 - How Many Tables
- 🔗 题目网址: HDU 1213 | 有多少张桌子
- 💡 推荐理由: 与 1232 逻辑相似,但将背景切换为社交关系(朋友圈)。它能帮你进一步巩固并查集的统计方法。
- 🎯 练习重点: * 练习如何在所有合并操作结束后,统计最终有多少个"Boss"(即满足
parent[i] == i的节点个数)。
3️⃣ 【逻辑进阶】HDU 1272 - 小希的迷宫
- 🔗 题目网址: HDU 1272 | 小希的迷宫
- 💡 推荐理由: 这是一道进阶题,不仅考察连通性,还引入了对**"环(Cycle)"**的判定。
- 🧠 核心逻辑:
- 成环判定: 如果在合并两个点之前,发现它们的 Boss 已经是同一个人,说明它们之间已存在路径。若此时再连一条路,则会形成环(迷宫通常要求不含环)。
- 全连通判定: 合并结束后,需要额外检查是否所有的点都归属于同一个集合。
💡 记录到 CSDN 的小贴士
并查集的核心思想:
- Find: 寻找所属集合的代表(Boss)。
- Union: 判定两个元素是否属于同一集合,若不属于则合并。
- 路径压缩: 这是保证效率的灵魂,让查找过程从 O ( N ) O(N) O(N) 降低到近乎 O ( 1 ) O(1) O(1)。