오늘의 인기 글
최근 글
최근 댓글
Today
Total
01-23 00:02
관리 메뉴

우노

[DFS] 백준 1707번 “이분 그래프” Python 풀이 본문

Algorithm/DFS

[DFS] 백준 1707번 “이분 그래프” Python 풀이

운호(Noah) 2022. 11. 13. 15:49

문제 링크

풀이

  • 이분 그래프(Bipartite Graph)란?

    • 인접한 정점끼리 서로 다른 색으로 칠해서 모든 정점을 두 가지 색으로만 칠할 수 있는 그래프입니다.
  • 탐색을 진행하며, 현재 노드와 이웃한 노드의 색을 확인하고, 동일한 색으로 칠해져있다면, 이분 그래프가 아닌 것으로 판단합니다.

코드

import sys
sys.setrecursionlimit(10**6)

# 테스트 케이스의 개수
t = int(sys.stdin.readline())

# 현재 노드와 이웃한 노드 탐색
def dfs(node):

    global result

    for neighbor in graph[node]:

        # 이웃 노드에 색칠이 되어있지 않다면
        if (visited[neighbor] == -1):

            # 현재 노드가 1로 색칠되어있다면
            if (visited[node] == 1):
                visited[neighbor] = 2
            # 현재 노드가 2로 색칠되어있다면
            if (visited[node] == 2):
                visited[neighbor] = 1

            dfs(neighbor)

        # 이웃 노드에 색칠이 되어있다면
        else:

            # 현재 노드와 동일한 색깔이라면
            if (visited[node] == visited[neighbor]):

                result = False
                return

for _ in range(t):

    # 정점의 개수 V와 간선의 개수 E
    v, e = map(int, sys.stdin.readline().split())

    # 색칠 여부 저장
    visited = [-1] * (v+1)

    # 양방향 간선 정보 저장
    graph = [[] for _ in range(v+1)]

    # 양방향 간선 정보 저장
    for _ in range(e):
        start, end = map(int, sys.stdin.readline().split())
        graph[start].append(end)
        graph[end].append(start)

    # 이분 그래프 여부
    result = True

    # 모든 노드 탐색
    for i in range(1, v+1):

        # 현재 노드가 색칠 되어있지 않다면
        if (visited[i] == -1):

            # 현재 노드를 색칠
            visited[i] = 1

            # 이웃한 노드에 대해서 색칠
            dfs(i)

            # 현재 노드로부터 이분 그래프가 아닌것을 확인했다면
            if (result == False):
                break

    # 이분 그래프가 아니라면
    if (result == False):
        print("NO")
    # 이분 그래프라면
    else:
        print("YES")

참고

Comments