Dfs算法的递归实现
时间: 2023-11-25 17:50:13 浏览: 72
以下是DFS算法的递归实现:
```python
# 定义一个图的类
class Graph:
def __init__(self, graph_dict=None):
if graph_dict is None:
graph_dict = {}
self.__graph_dict = graph_dict
# 添加节点
def add_node(self, node):
if node not in self.__graph_dict:
self.__graph_dict[node] = []
# 添加边
def add_edge(self, edge):
edge = set(edge)
(node1, node2) = tuple(edge)
if node1 in self.__graph_dict:
self.__graph_dict[node1].append(node2)
else:
self.__graph_dict[node1] = [node2]
# DFS算法的递归实现
def dfs(self, start, visited=None):
if visited is None:
visited = set()
visited.add(start)
print(start)
for next_node in self.__graph_dict[start]:
if next_node not in visited:
self.dfs(next_node, visited)
return visited
# 创建一个图
graph = Graph()
# 添加节点
graph.add_node('A')
graph.add_node('B')
graph.add_node('C')
graph.add_node('D')
graph.add_node('E')
graph.add_node('F')
# 添加边
graph.add_edge(('A', 'B'))
graph.add_edge(('A', 'C'))
graph.add_edge(('B', 'D'))
graph.add_edge(('B', 'E'))
graph.add_edge(('C', 'F'))
# 执行DFS算法
graph.dfs('A')
```
阅读全文