称为并查集(或不相交集)的算法负责维护不同的集合,并提供操作来验证集合中的成员资格并将集合组合在一起。它熟练地处理并集和查找操作,这对于维护元素之间的当前连接信息至关重要。
语法
为了确保清晰度,让我们首先理解即将在接下来的代码示例中使用的方法的语法。
// Method to perform Union operation void Union(int x, int y); // Method to find the representative element of a set int Find(int x);
算法
并查算法由两个基本操作组成 - 并集和查找。并集运算合并两个集合,查找运算确定集合的代表元素。通过迭代应用并查运算,我们可以构建高效的并查数据结构。
按等级联合
按等级联合技术用于通过确保较小的树始终附加到较大的树的根来优化联合操作。这种方法可以防止树变得过于不平衡,从而导致查找操作效率低下。
按等级联合的算法如下 -
查找包含元素 x 和 y 的集合的代表(根元素)。
如果代表相同,则返回。
如果x的代表的等级大于y的代表的等级,则使y的代表指向x的代表,并更新x的代表的等级。
否则,使 x 的代表指向 y 的代表,并在必要时更新 y 的代表的排名。
路径压缩
路径压缩是另一种优化技术,可降低并查数据结构中树的高度。它的目的是在查找操作期间压平路径,从而为后续操作提供更短的路径。
路径压缩的算法如下 -
查找包含元素 x 的集合的代表(根元素)。
在遍历从x到其代表的路径时,使每个访问过的元素直接指向代表。
方法
现在我们已经了解了按等级并集和路径压缩的基本概念,让我们讨论在 C++ 中实现并查算法的两种不同方法。
方法一:基于数组的实现
在这种方法中,我们将每个集合表示为一个数组。每个索引处的值代表元素的父元素。最初,每个元素都是其自己的父元素,表明它是其集合的代表。
算法
让我们开始父数组的初始化过程。每个元素都将被分配其自己的父元素。
使用路径压缩实现查找操作。
使用 Union by Rank 实现 Union 运算。
示例
#include <iostream> #define MAX_SIZE 100 // Initialize parent array int parent[MAX_SIZE]; int rank[MAX_SIZE]; void makeSet(int n) { for (int i = 0; i < n; i++) { parent[i] = i; rank[i] = 0; } } int find(int x) { if (parent[x] != x) { parent[x] = find(parent[x]); // Path compression } return parent[x]; } void Union(int x, int y) { int xRoot = find(x); int yRoot = find(y); if (xRoot == yRoot) { return; } // Union by rank if (rank[xRoot] < rank[yRoot]) { parent[xRoot] = yRoot; } else if (rank[xRoot] > rank[yRoot]) { parent[yRoot] = xRoot; } else { parent[yRoot] = xRoot; rank[xRoot]++; } } int main() { // Usage example makeSet(10); // Assuming 10 elements in the set Union(1, 2); Union(3, 4); // Print parent array for (int i = 0; i < 10; i++) { std::cout << "Element " << i << " Parent: " << parent[i] << std::endl; } return 0; }
输出
Element 0 Parent: 0 Element 1 Parent: 1 Element 2 Parent: 1 Element 3 Parent: 3 Element 4 Parent: 3 Element 5 Parent: 5 Element 6 Parent: 6 Element 7 Parent: 7 Element 8 Parent: 8 Element 9 Parent: 9
方法 2:基于树的实现
为了描述我们研究中的集合,我们使用了基于树的方法。组中的每个项目都与其各自的父节点关联,同时我们指定根节点来表示该特定集合。
算法
初始化父数组,其中每个元素都是其自己的父元素。
使用路径压缩和递归树遍历来实现查找操作。
使用 Union by Rank 实现 Union 运算。
完整的可执行代码
示例
#include <iostream> #define MAX_SIZE 100 // Initialize parent array int parent[MAX_SIZE]; int rank[MAX_SIZE]; void makeSet(int n) { for (int i = 0; i < n; i++) { parent[i] = i; rank[i] = 0; } } int find(int x) { if (parent[x] != x) { parent[x] = find(parent[x]); // Path compression } return parent[x]; } void Union(int x, int y) { int xRoot = find(x); int yRoot = find(y); if (xRoot == yRoot) { return; } // Union by rank if (rank[xRoot] < rank[yRoot]) { parent[xRoot] = yRoot; } else if (rank[xRoot] > rank[yRoot]) { parent[yRoot] = xRoot; } else { parent[yRoot] = xRoot; rank[xRoot]++; } } int main() { // Usage example makeSet(10); // Assuming 10 elements in the set Union(1, 2); Union(3, 4); // Print parent array for (int i = 0; i < 10; i++) { std::cout << "Element " << i << " Parent: " << parent[i] << std::endl; } return 0; }
输出
Element 0 Parent: 0 Element 1 Parent: 1 Element 2 Parent: 1 Element 3 Parent: 3 Element 4 Parent: 3 Element 5 Parent: 5 Element 6 Parent: 6 Element 7 Parent: 7 Element 8 Parent: 8 Element 9 Parent: 9
结论
总而言之,按等级并集和路径压缩是并查算法中的关键技术。它们分别优化了联合和查找操作,从而提高了性能并实现了高效的连接信息管理。通过在 C++ 中实现这些技术,我们可以有效地解决与集合、连通性和图相关的问题。
总而言之,我们介绍了语法、分步算法,并提供了两个真实的 C++ 可执行代码示例。通过理解和应用按等级并集和路径压缩,您可以增强算法技能并更有效地解决复杂问题。
以上是并查集算法中的等级合并和路径压缩的详细内容。更多信息请关注PHP中文网其他相关文章!

C 在现代编程中仍然具有重要相关性。1)高性能和硬件直接操作能力使其在游戏开发、嵌入式系统和高性能计算等领域占据首选地位。2)丰富的编程范式和现代特性如智能指针和模板编程增强了其灵活性和效率,尽管学习曲线陡峭,但其强大功能使其在今天的编程生态中依然重要。

C 学习者和开发者可以从StackOverflow、Reddit的r/cpp社区、Coursera和edX的课程、GitHub上的开源项目、专业咨询服务以及CppCon等会议中获得资源和支持。1.StackOverflow提供技术问题的解答;2.Reddit的r/cpp社区分享最新资讯;3.Coursera和edX提供正式的C 课程;4.GitHub上的开源项目如LLVM和Boost提升技能;5.专业咨询服务如JetBrains和Perforce提供技术支持;6.CppCon等会议有助于职业

C#适合需要高开发效率和跨平台支持的项目,而C 适用于需要高性能和底层控制的应用。1)C#简化开发,提供垃圾回收和丰富类库,适合企业级应用。2)C 允许直接内存操作,适用于游戏开发和高性能计算。

C 持续使用的理由包括其高性能、广泛应用和不断演进的特性。1)高效性能:通过直接操作内存和硬件,C 在系统编程和高性能计算中表现出色。2)广泛应用:在游戏开发、嵌入式系统等领域大放异彩。3)不断演进:自1983年发布以来,C 持续增加新特性,保持其竞争力。

C 和XML的未来发展趋势分别为:1)C 将通过C 20和C 23标准引入模块、概念和协程等新特性,提升编程效率和安全性;2)XML将继续在数据交换和配置文件中占据重要地位,但会面临JSON和YAML的挑战,并朝着更简洁和易解析的方向发展,如XMLSchema1.1和XPath3.1的改进。

现代C 设计模式利用C 11及以后的新特性实现,帮助构建更灵活、高效的软件。1)使用lambda表达式和std::function简化观察者模式。2)通过移动语义和完美转发优化性能。3)智能指针确保类型安全和资源管理。

C 多线程和并发编程的核心概念包括线程的创建与管理、同步与互斥、条件变量、线程池、异步编程、常见错误与调试技巧以及性能优化与最佳实践。1)创建线程使用std::thread类,示例展示了如何创建并等待线程完成。2)同步与互斥使用std::mutex和std::lock_guard保护共享资源,避免数据竞争。3)条件变量通过std::condition_variable实现线程间的通信和同步。4)线程池示例展示了如何使用ThreadPool类并行处理任务,提高效率。5)异步编程使用std::as

C 的内存管理、指针和模板是核心特性。1.内存管理通过new和delete手动分配和释放内存,需注意堆和栈的区别。2.指针允许直接操作内存地址,使用需谨慎,智能指针可简化管理。3.模板实现泛型编程,提高代码重用性和灵活性,需理解类型推导和特化。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

Dreamweaver CS6
视觉化网页开发工具

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

SecLists
SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。