无向图 python
时间: 2024-09-13 12:00:49 浏览: 47
无向图是图论中的一个基本概念,它是由一组顶点和一组能够将这些顶点两两相连的边组成的。在无向图中,每条边连接两个顶点,并且不区分方向,即边 (u, v) 与边 (v, u) 是相同的。无向图可以用来表示各种实体之间的对等关系。
在Python中,可以使用多种方式来表示无向图。最简单的一种方法是使用邻接矩阵,另一种方法是使用邻接表。
1. 邻接矩阵:是一个二维数组,其中的元素表示顶点之间的连接关系。如果顶点i和顶点j之间有边相连,则矩阵的第i行第j列的元素为1(或者边的权重),否则为0。
2. 邻接表:通常用字典(或列表)来实现,字典的键是顶点,值是与该顶点相连的其他顶点的列表。
下面是一个简单的Python代码示例,使用邻接表来表示一个无向图,并实现图的创建和边的添加:
```python
class UndirectedGraph:
def __init__(self):
self.graph = {} # 使用字典来存储邻接表
def add_vertex(self, v):
"""添加顶点"""
if v not in self.graph:
self.graph[v] = []
def add_edge(self, v1, v2):
"""添加边"""
if v1 in self.graph and v2 in self.graph:
self.graph[v1].append(v2)
self.graph[v2].append(v1)
def print_graph(self):
"""打印图"""
for vertex in self.graph:
print(f"{vertex}: {self.graph[vertex]}")
# 使用示例
ug = UndirectedGraph()
ug.add_vertex(0)
ug.add_vertex(1)
ug.add_vertex(2)
ug.add_vertex(3)
ug.add_edge(0, 1)
ug.add_edge(0, 2)
ug.add_edge(1, 2)
ug.add_edge(2, 3)
ug.print_graph()
```
运行上述代码后,会输出图中各个顶点及其连接的其他顶点,例如:
```
0: [1, 2]
1: [0, 2]
2: [0, 1, 3]
3: [2]
```
阅读全文