编程完成基于邻接表的图的非递归深度遍历和广度遍历
时间: 2024-02-13 11:02:01 浏览: 52
好的,下面是基于邻接表的图的非递归深度遍历和广度遍历的 Python 代码实现。
首先,我们需要定义一个邻接表的类 Graph,用于表示图结构。在这个类中,我们需要实现添加节点、添加边、深度遍历和广度遍历等方法。
```
class Graph:
def __init__(self):
self.adj_list = {}
def add_node(self, node):
if node not in self.adj_list:
self.adj_list[node] = []
def add_edge(self, node1, node2):
if node1 not in self.adj_list:
self.adj_list[node1] = []
if node2 not in self.adj_list:
self.adj_list[node2] = []
self.adj_list[node1].append(node2)
self.adj_list[node2].append(node1)
```
接下来,我们实现非递归深度遍历方法 dfs。这个方法需要使用一个栈来存储待访问的节点。我们从起始节点开始访问,将其入栈,然后不断从栈中弹出节点,访问其邻居节点,并将其邻居节点入栈。直到栈为空时,遍历结束。
```
def dfs(self, start):
stack = [start]
visited = set()
while stack:
node = stack.pop()
if node not in visited:
print(node, end=' ')
visited.add(node)
for neighbor in self.adj_list[node]:
stack.append(neighbor)
```
最后,我们实现广度遍历方法 bfs。这个方法需要使用一个队列来存储待访问的节点。我们从起始节点开始访问,将其入队,然后不断从队列中弹出节点,访问其邻居节点,并将其邻居节点入队。直到队列为空时,遍历结束。
```
def bfs(self, start):
queue = [start]
visited = set()
while queue:
node = queue.pop(0)
if node not in visited:
print(node, end=' ')
visited.add(node)
for neighbor in self.adj_list[node]:
queue.append(neighbor)
```
完整代码如下:
```
class Graph:
def __init__(self):
self.adj_list = {}
def add_node(self, node):
if node not in self.adj_list:
self.adj_list[node] = []
def add_edge(self, node1, node2):
if node1 not in self.adj_list:
self.adj_list[node1] = []
if node2 not in self.adj_list:
self.adj_list[node2] = []
self.adj_list[node1].append(node2)
self.adj_list[node2].append(node1)
def dfs(self, start):
stack = [start]
visited = set()
while stack:
node = stack.pop()
if node not in visited:
print(node, end=' ')
visited.add(node)
for neighbor in self.adj_list[node]:
stack.append(neighbor)
def bfs(self, start):
queue = [start]
visited = set()
while queue:
node = queue.pop(0)
if node not in visited:
print(node, end=' ')
visited.add(node)
for neighbor in self.adj_list[node]:
queue.append(neighbor)
# example
g = Graph()
g.add_edge(1, 2)
g.add_edge(1, 3)
g.add_edge(2, 4)
g.add_edge(2, 5)
g.add_edge(3, 6)
print("DFS:")
g.dfs(1)
print()
print("BFS:")
g.bfs(1)
print()
```
阅读全文
相关推荐
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="-"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="zip"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="rar"
data:image/s3,"s3://crabby-images/76d5d/76d5dcefc5ad32aa65e7d5f6e5b202b09b84830d" alt="application/x-rar"
data:image/s3,"s3://crabby-images/e09fa/e09fa4d37aa4b8ac63bbefa75d17fdf661f74dab" alt="doc"
data:image/s3,"s3://crabby-images/67779/677799e3f0cb300878598cdf44af630e5aa7bdbb" alt="-"
data:image/s3,"s3://crabby-images/e09fa/e09fa4d37aa4b8ac63bbefa75d17fdf661f74dab" alt="-"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="-"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="-"
data:image/s3,"s3://crabby-images/c7f95/c7f957a578cbb465f17670ca5ec5de6d8fbcb44e" alt="-"
data:image/s3,"s3://crabby-images/6eee2/6eee29554420e01e83364d49443b3b12df11c8af" alt=""