燃爆全场!Python并查集:数据结构界的网红,让你的代码炫酷无比!

简介: 【7月更文挑战第16天】并查集,Python中的效率明星,处理不相交集合合并与查询。用于社交网络分析、图像处理、图论算法等领域。优雅实现结合路径压缩和按秩合并

在编程的世界里,总有一些数据结构以其独特的魅力和高效的性能脱颖而出,成为众多开发者追捧的“网红”。今天,我们要介绍的这位明星,就是Python中的并查集(Union-Find)——它不仅在解决特定问题上大放异彩,更以其优雅的设计和强大的功能,让你的代码炫酷无比,燃爆全场!

并查集:数据结构的璀璨新星
并查集,这个听起来略显陌生的名字,实则隐藏着巨大的能量。它主要用于处理一些不相交集合(Disjoint Sets)的合并及查询问题,如判断两个元素是否属于同一集合、合并两个集合等。在社交网络分析、图像处理、图论算法等多个领域,并查集都展现出了其不可替代的价值。

最佳实践:优雅实现并查集
在Python中,实现一个高效且优雅的并查集并不难。以下是一个结合了路径压缩和按秩合并的并查集实现示例:

python
class UnionFind:
def init(self, size):
self.parent = list(range(size))
self.rank = [0] * size

def find(self, p):  
    if self.parent[p] != p:  
        # 路径压缩,将p的父节点直接指向根节点  
        self.parent[p] = self.find(self.parent[p])  
    return self.parent[p]  

def union(self, p, q):  
    rootP = self.find(p)  
    rootQ = self.find(q)  
    if rootP == rootQ:  
        return False  # p和q已经在同一个集合中  

    # 按秩合并,确保合并后树的深度尽可能小  
    if self.rank[rootP] > self.rank[rootQ]:  
        self.parent[rootQ] = rootP  
    elif self.rank[rootP] < self.rank[rootQ]:  
        self.parent[rootP] = rootQ  
    else:  
        self.parent[rootQ] = rootP  
        self.rank[rootP] += 1  
    return True  

使用示例

uf = UnionFind(10)
uf.union(0, 1)
uf.union(1, 2)
print(uf.find(0) == uf.find(2)) # 输出: True,表示0和2属于同一集合
并查集的应用:炫酷代码的背后
并查集不仅仅是一个数据结构,更是解决特定问题的利器。比如,在社交网络分析中,我们可以利用并查集快速判断两个用户是否处于同一社交圈内;在图论算法中,它可以用于实现Kruskal算法,构建最小生成树;在图像处理中,它能帮助我们标记出所有的连通分量。

结语
并查集,这位数据结构界的网红,以其简洁的设计、高效的性能和广泛的应用场景,成为了众多开发者手中的“神器”。在你的编程之路上,掌握并查集,不仅能够让你轻松应对复杂的关系处理问题,更能让你的代码炫酷无比,燃爆全场!无论是对于初学者还是经验丰富的开发者来说,学习和掌握并查集都是一次极具价值的探索之旅。现在,就让我们一起拥抱并查集,开启更加精彩的编程之旅吧!

相关文章
|
20天前
|
数据采集 机器学习/深度学习 编解码
从零复现Google Veo 3:从数据预处理到视频生成的完整Python代码实现指南
本文详细介绍了一个简化版 Veo 3 文本到视频生成模型的构建过程。首先进行了数据预处理,涵盖了去重、不安全内容过滤、质量合规性检查以及数据标注等环节。
106 5
从零复现Google Veo 3:从数据预处理到视频生成的完整Python代码实现指南
|
24天前
|
NoSQL MongoDB 开发者
Python与MongoDB的亲密接触:从入门到实战的代码指南
本文详细介绍了Python与MongoDB结合使用的实战技巧,涵盖环境搭建、连接管理、CRUD操作、高级查询、索引优化、事务处理及性能调优等内容。通过15个代码片段,从基础到进阶逐步解析,帮助开发者掌握这对黄金组合的核心技能。内容包括文档结构设计、批量操作优化、聚合管道应用等实用场景,适合希望高效处理非结构化数据的开发者学习参考。
54 0
|
1月前
|
机器学习/深度学习 人工智能 PyTorch
200行python代码实现从Bigram模型到LLM
本文从零基础出发,逐步实现了一个类似GPT的Transformer模型。首先通过Bigram模型生成诗词,接着加入Positional Encoding实现位置信息编码,再引入Single Head Self-Attention机制计算token间的关系,并扩展到Multi-Head Self-Attention以增强表现力。随后添加FeedForward、Block结构、残差连接(Residual Connection)、投影(Projection)、层归一化(Layer Normalization)及Dropout等组件,最终调整超参数完成一个6层、6头、384维度的“0.0155B”模型
118 11
200行python代码实现从Bigram模型到LLM
|
1月前
|
机器学习/深度学习 算法 PyTorch
从零开始200行python代码实现LLM
本文从零开始用Python实现了一个极简但完整的大语言模型,帮助读者理解LLM的工作原理。首先通过传统方法构建了一个诗词生成器,利用字符间的概率关系递归生成文本。接着引入PyTorch框架,逐步重构代码,实现了一个真正的Bigram模型。文中详细解释了词汇表(tokenizer)、张量(Tensor)、反向传播、梯度下降等关键概念,并展示了如何用Embedding层和线性层搭建模型。最终实现了babyGPT_v1.py,一个能生成类似诗词的简单语言模型。下一篇文章将在此基础上实现自注意力机制和完整的GPT模型。
125 14
从零开始200行python代码实现LLM
|
2月前
|
机器学习/深度学习 算法 测试技术
图神经网络在信息检索重排序中的应用:原理、架构与Python代码解析
本文探讨了基于图的重排序方法在信息检索领域的应用与前景。传统两阶段检索架构中,初始检索速度快但结果可能含噪声,重排序阶段通过强大语言模型提升精度,但仍面临复杂需求挑战
84 0
图神经网络在信息检索重排序中的应用:原理、架构与Python代码解析
|
2月前
|
存储 机器学习/深度学习 人工智能
多模态RAG实战指南:完整Python代码实现AI同时理解图片、表格和文本
本文探讨了多模态RAG系统的最优实现方案,通过模态特定处理与后期融合技术,在性能、准确性和复杂度间达成平衡。系统包含文档分割、内容提取、HTML转换、语义分块及向量化存储五大模块,有效保留结构和关系信息。相比传统方法,该方案显著提升了复杂查询的检索精度(+23%),并支持灵活升级。文章还介绍了查询处理机制与优势对比,为构建高效多模态RAG系统提供了实践指导。
417 0
多模态RAG实战指南:完整Python代码实现AI同时理解图片、表格和文本
|
2月前
|
数据采集 运维 API
把Postman调试脚本秒变Python采集代码的三大技巧
本文介绍了如何借助 Postman 调试工具快速生成 Python 爬虫代码,并结合爬虫代理实现高效数据采集。文章通过“跨界混搭”结构,先讲解 Postman 的 API 调试功能,再映射到 Python 爬虫技术,重点分享三大技巧:利用 Postman 生成请求骨架、通过 Session 管理 Cookie 和 User-Agent,以及集成代理 IP 提升稳定性。以票务信息采集为例,展示完整实现流程,探讨其在抗封锁、团队协作等方面的价值,帮助开发者快速构建生产级爬虫代码。
103 1
把Postman调试脚本秒变Python采集代码的三大技巧
232.用栈实现队列,225. 用队列实现栈
在232题中,通过两个栈(`stIn`和`stOut`)模拟队列的先入先出(FIFO)行为。`push`操作将元素压入`stIn`,`pop`和`peek`操作则通过将`stIn`的元素转移到`stOut`来实现队列的顺序访问。 225题则是利用单个队列(`que`)模拟栈的后入先出(LIFO)特性。通过多次调整队列头部元素的位置,确保弹出顺序符合栈的要求。`top`操作直接返回队列尾部元素,`empty`判断队列是否为空。 两题均仅使用基础数据结构操作,展示了栈与队列之间的转换逻辑。
|
1月前
|
编译器 C语言 C++
栈区的非法访问导致的死循环(x64)
这段内容主要分析了一段C语言代码在VS2022中形成死循环的原因,涉及栈区内存布局和数组越界问题。代码中`arr[15]`越界访问,修改了变量`i`的值,导致`for`循环条件始终为真,形成死循环。原因是VS2022栈区从低地址到高地址分配内存,`arr`数组与`i`相邻,`arr[15]`恰好覆盖`i`的地址。而在VS2019中,栈区先分配高地址再分配低地址,因此相同代码表现不同。这说明编译器对栈区内存分配顺序的实现差异会导致程序行为不一致,需避免数组越界以确保代码健壮性。
21 0
栈区的非法访问导致的死循环(x64)
|
5月前
|
算法 调度 C++
STL——栈和队列和优先队列
通过以上对栈、队列和优先队列的详细解释和示例,希望能帮助读者更好地理解和应用这些重要的数据结构。
78 11

推荐镜像

更多