알고리즘

BFS/ DFS 개념

rins 2021. 4. 19. 21:25

DFS

개념

깊이 우선 탐색이라고 부르며 그래프에서 깊은 부분을 우선적으로 탐색하는 알고리즘이다.

노드와 간선으로 구성되어 있으며 그래프 탐색은 하나의 노드를 시작으로 다수의 노드를 방문하는 것을 의미한다.

인접행렬과 인접 리스트로 그래프를 표현하는 방식은 두가지가 있고, 인접행렬은 메모리를 많이 차지하는 대신 바로 관계를 알 수 있다는 장점이 있으며, 인접리스트는 메모리는 조금 차지하나 두 노드가 연결되어있는지 정보를 얻는 속도는 느리다.

구현

def dfs(graph, visited, v):
		# 방문 하지 않은 노드이면
    if not visited[v]:
				# 방문했다는 표시
        visited[v] = True
        print(v, end=' ')
				# 해당 노드에 인접한 노드 방문
        for node in graph[v]:
            dfs(graph, visited, node)

# 그래프
near_list = [
    [],
    [2, 3, 8],
    [1, 7],
    [1, 4, 5],
    [3, 5],
    [3, 4],
    [7],
    [2, 6, 8],
    [1, 7]
]

# 방문 표시할 리스트 초기화
visited = [False] * len(near_list)
result = dfs(graph=near_list, visited=visited, v=1)

BFS

개념

너비우선 탐색의 의미로 가까운 노드부터 탐색하는 알고리즘이다.

구현

def bfs(graph, visited, v):
    queue = [v]
    visited[v] = True

    while queue:
        this = queue.pop(0)
        print(this, end=" ")
        for node in graph[this]:
            if not visited[node]:
                visited[node] = True
                queue.append(node)

near_list = [
    [],
    [2, 3, 8],
    [1, 7],
    [1, 4, 5],
    [3, 5],
    [3, 4],
    [7],
    [2, 6, 8],
    [1, 7]
]

visited = [False] * len(near_list)

result = bfs(graph=near_list, visited=visited, v=1)

 

'알고리즘' 카테고리의 다른 글

이진탐색  (0) 2021.04.19