不容错过!Python中图的精妙表示与高效遍历策略,提升你的编程艺术感

简介: 本文介绍了Python中图的表示方法及遍历策略。图可通过邻接表或邻接矩阵表示,前者节省空间适合稀疏图,后者便于检查连接但占用更多空间。文章详细展示了邻接表和邻接矩阵的实现,并讲解了深度优先搜索(DFS)和广度优先搜索(BFS)的遍历方法,帮助读者掌握图的基本操作和应用技巧。

在编程的浩瀚宇宙中,图(Graph)作为一种能够表达复杂数据关系的结构,其重要性不言而喻。Python,作为一门灵活且功能强大的编程语言,为我们提供了多种实现和遍历图的方法。今天,我们将一同探索Python中图的精妙表示方式以及高效遍历策略,旨在提升你的编程艺术感。

图的表示
在Python中,图通常可以通过邻接表(Adjacency List)或邻接矩阵(Adjacency Matrix)来表示。邻接表更节省空间,特别是对于稀疏图;而邻接矩阵则便于检查任意两点是否直接相连,但空间复杂度较高。

邻接表表示
python

使用字典实现邻接表

graph = {
'A': ['B', 'C'],
'B': ['A', 'D', 'E'],
'C': ['A', 'F'],
'D': ['B'],
'E': ['B', 'F', 'G'],
'F': ['C', 'E'],
'G': ['E']
}

访问节点'A'的邻接节点

print("A的邻接节点:", graph['A'])
邻接矩阵表示
python

使用二维列表(或NumPy数组)实现邻接矩阵

假设图中只有上述7个节点

n = len(graph)
adjmatrix = [[0] * n for in range(n)]

根据邻接表填充邻接矩阵

for node in graph:
for neighbor in graph[node]:
adj_matrix[ord(node) - ord('A')][ord(neighbor) - ord('A')] = 1

打印邻接矩阵(部分)

print("邻接矩阵的部分内容:")
for row in adj_matrix[:3]:
print(row[:3]) # 仅打印前3x3的部分以节省空间
图的遍历
图的遍历主要有深度优先搜索(DFS)和广度优先搜索(BFS)两种策略。

深度优先搜索(DFS)
python
def dfs(graph, start, visited=None):
if visited is None:
visited = set()
visited.add(start)
print(start, end=' ') # 输出访问顺序
for neighbor in graph[start]:
if neighbor not in visited:
dfs(graph, neighbor, visited)

从节点'A'开始DFS遍历

dfs(graph, 'A')
广度优先搜索(BFS)
python
from collections import deque

def bfs(graph, start):
visited = set()
queue = deque([start])
visited.add(start)

while queue:  
    node = queue.popleft()  
    print(node, end=' ')  # 输出访问顺序  
    for neighbor in graph[node]:  
        if neighbor not in visited:  
            visited.add(neighbor)  
            queue.append(neighbor)  

从节点'A'开始BFS遍历

bfs(graph, 'A')
结语
通过上面的示例,我们不仅学会了如何在Python中使用邻接表和邻接矩阵来表示图,还掌握了DFS和BFS两种高效遍历图的方法。这些基础但强大的技能,将帮助你解决更复杂的图论问题,并在实际编程中展现出更高的艺术感。无论是处理社交网络中的关系链,还是解决迷宫问题,图的精妙表示与高效遍历策略都是你不可或缺的工具。继续深入探索,让编程之路更加宽广而精彩!

相关文章
|
2月前
|
算法 计算机视觉 Python
Python并查集大揭秘:让你在算法界呼风唤雨,秒杀一切复杂场景!
在编程与算法的广袤天地中,总有一些工具如同神兵利器,能够助你一臂之力,在复杂的问题前游刃有余。今天,我们就来深入探讨这样一件神器——Python并查集(Union-Find),看看它是如何让你在算法界呼风唤雨,轻松应对各种复杂场景的。
63 2
|
2月前
|
算法 开发者 计算机视觉
Python并查集:数据结构界的肌肉男,让你在编程路上无所畏惧!
在编程的浩瀚宇宙中,数据结构如同基石,构建了解决问题的坚实框架。而并查集(Union-Find),这位数据结构界的“肌肉男”,以其独特的魅力和强大的功能,让无数开发者在面对复杂关系处理时,都能感受到前所未有的从容与自信。今天,就让我们一同揭开并查集的神秘面纱,看看它是如何成为你编程路上的得力助手的。
29 0
|
4月前
|
Python
不容错过!Python中图的精妙表示与高效遍历策略,提升你的编程艺术感
【7月更文挑战第11天】在Python编程中,图以邻接表或邻接矩阵表示,前者节省空间,后者利于查询连接。通过字典实现邻接表,二维列表构建邻接矩阵。图的遍历包括深度优先搜索(DFS)和广度优先搜索(BFS)。DFS使用递归,BFS借助队列。这些基础技巧对于解决复杂数据关系问题,如社交网络分析或迷宫求解,至关重要,能提升编程艺术。
62 5
|
5月前
|
索引 Python 安全
【Python内功心法】:深挖内置函数,释放语言潜能
【Python内功心法】:深挖内置函数,释放语言潜能
|
6月前
|
人工智能 程序员 开发者
【笔记】效率之门——Python中的函数式编程技巧
Python函数式编程 我的AI Studio项目:【笔记】LearnDL第三课:Python高级编程——抽象与封装 - 飞桨AI Studio (baidu.com)
43 0
|
6月前
|
机器学习/深度学习 自然语言处理 API
有一点python基础,想玩大模型,不知从何入手。快速入门。
有一点python基础,想玩大模型,不知从何入手。快速入门。
663 0
|
存储 算法 程序员
人理解迭代,神则体会递归,从电影艺术到Python代码实现神的逆向思维模式
“从来如此,便对么?”,鲁迅先生在《狂人日记》中借狂人之口在月光下发出的质疑与呐喊,是的,从来如此,一般人的思维模式就是从来如此,以高数为例子,我们大抵都是先从数分、线代、解几去学泛函、抽代、拓扑等,其实就是按照标准路子来,这样做理论上可以增加对已学知识的理解程度,并对某些数分、线代中的问题看清其本质有所帮助。数学归纳法其实就是一种迭代(iteration),从一个简单的起点,推广到一般情况。而递归(recursion),则是一种反人类的逆向思维模式,作为研发人员,掌握这种反常识的思维逻辑是非常必要的,这里我们以一个推理故事为开端
人理解迭代,神则体会递归,从电影艺术到Python代码实现神的逆向思维模式