최근 수정 시각 : 2025-10-22 21:14:59

그래프(이산수학)

그래프 이론에서 넘어옴

이산수학
Discrete Mathematics
{{{#!wiki style="margin: 0 -10px -5px; min-height: calc(1.5em + 5px)"
{{{#!folding [ 펼치기 · 접기 ]
{{{#!wiki style="margin: -5px -1px -11px"
<bgcolor=#46786a> 이론
<colbgcolor=#46786a> 기본 대상 수학기초론(수리논리학 · 집합론) · 수열 · 조합 · 알고리즘 · 확률
다루는 대상과 주요 토픽
수열 등차수열(뛰어 세기) · 등비수열 · 계차수열 · 조화수열 · 귀납적 정의(점화식) · 급수 · 규칙과 대응 · 규칙 찾기 · 피보나치 수열 · 읽고 말하기 수열 · 생성함수
조합 경우의 수(/공식) · 순열(완전 순열 · 염주 순열) · 치환 · 분할(분할수) · 최단거리 · 제1종 스털링 수 · 제2종 스털링 수 · 카탈랑 수 · 벨 수 · 라흐 수 · 포함·배제의 원리 · 더블 카운팅 · 조합론
그래프 수형도(트리) · 인접행렬 · 마방진 · 마법진 · 한붓그리기(해밀턴 회로) · 쾨니히스베르크 다리 건너기 문제
기타 P-NP 문제미해결 · 4색정리 · 이항정리(파스칼의 삼각형) · 이산 푸리에 변환 · 비둘기 집의 원리 · 상트페테르부르크의 역설 · 투표의 역설 · 에르고딕 가설미해결 · 콜라츠 추측미해결 · 시행착오(예상과 확인) · 불 논리 · 브라에스 역설 · 포함-배제의 원리
관련 문서 논리학 관련 정보 · 수학 관련 정보 · 컴퓨터 관련 정보 · 틀:수학기초론 · 틀:통계학 · 틀:이론 컴퓨터 과학 }}}}}}}}}


[[이론 컴퓨터 과학|'''이론 컴퓨터 과학
{{{#!wiki style="display: inline-block; font-family:Times New Roman, serif;font-style:italic"
]]
{{{#!wiki style="margin: 0 -10px -5px; min-height: calc(1.5em + 5px)"
{{{#!folding [ 펼치기 · 접기 ]
{{{#!wiki style="margin: -5px -1px -11px"
<colbgcolor=#a36,#a36> 이론
기본 대상 수학기초론{수리논리학(논리 연산) · 계산 가능성 이론 · 범주론 · 집합론} · 이산수학(그래프 이론) · 수치해석학 · 확률론통계학 · 선형대수학
다루는 대상과 주요 토픽
계산 가능성 이론 재귀함수 · 튜링 머신 · 람다대수 · 처치-튜링 명제 · 바쁜 비버 · 디지털 물리학
오토마타 이론 FSM · 푸시다운 · 튜링 머신(폰노이만 구조) · 정규 표현식 · 콘웨이의 생명 게임 · 형식언어
계산 복잡도 이론 점근 표기법 · 튜링 기계^고전, 양자, 비결정론적, 병렬 임의접근 기계^ · 알고리즘 · 자료구조 · 알고리즘 패러다임(그리디 알고리즘, 동적 계획법)
정보이론 정보 엔트로피 · 데이터 압축(무손실 압축 포맷 · 손실 압축 포맷) · 채널 코딩(채널 용량) · 알고리즘 정보 이론(AIT) · 양자정보과학
프로그래밍 언어론 프로그래밍 언어(함수형 언어 · 객체 지향 프로그래밍 · 증명보조기) · 메타프로그래밍 · 람다 대수 · 유형 이론 · 프로그래밍 언어 의미론 · 어휘 분석 · 파싱 · 구문 트리(완전 구문 트리 · 추상 구문 트리) · 컴파일러 이론
주요 알고리즘 및 자료구조
기초 정렬 알고리즘 · 순서도 · 탐색 알고리즘
추상적 자료형 및 구현 배열^벡터^ · 리스트^연결 리스트^ · 셋(set) · 트리^레드-블랙 트리, B-트리, , 피보나치 힙^ · · 스택
수학적 최적화 <keepall> 조합 최적화 외판원 순회 문제 · 담금질 기법 · 유전 알고리즘 · 기계학습
<keepall> 볼록 최적화 내부점 방법 · 경사하강법
<keepall> 선형계획법 심플렉스법
계산 수론 및 암호학 밀러-라빈 소수판별법 · Pollard-rho 알고리즘 · 쇼어 알고리즘 · LLL 알고리즘 · 해시(MD5 · 암호화폐 · 사전 공격(레인보우 테이블) · SHA) · 양자 암호 · 난수생성
<keepall> 대칭키 암호화 방식 블록 암호 알고리즘(파이스텔 네트워크 · DES · AES · ARIA · LEA · Camellia) · 스트림 암호 알고리즘(RC4)
<keepall> 공개키 암호화 방식 공개키 암호 알고리즘(타원 곡선 암호 · RSA) · 신원 기반 암호 알고리즘(SM9)
계산기하학 볼록 껍질 · 들로네 삼각분할 및 보로노이 도형^Fortune의 line-sweeping 알고리즘^ · 범위 탐색^vp-tree, R-tree^ · k-NN
그래프 이론 탐색^BFS, DFS, 다익스트라 알고리즘, A* 알고리즘^ · 에드몬드-카프 · 크루스칼 알고리즘 · 위상 정렬 · 네트워크 이론
정리
정지 문제대각선 논법 · 암달의 법칙 · P-NP 문제미해결 · 콜라츠 추측미해결
틀:이산수학 · 틀:수학기초론 · 틀:컴퓨터공학 }}}}}}}}}
파일:그래프(이산수학).svg파일:그래프(이산수학)_White.svg
무향 단순그래프의 예시 (그림 1)
1. 개요2. 용어와 개념
2.1. 정의
2.1.1. 그래프
2.1.1.1. 유향그래프2.1.1.2. 다중그래프2.1.1.3. 유향 다중그래프2.1.1.4. 가중 그래프
2.1.2. 기본 개념
2.1.2.1. 이웃2.1.2.2. 차수
2.1.2.2.1. 입력차수와 출력차수
2.2. 구조 및 분류
2.2.1. 완전 그래프2.2.2. 보행, 사이클, 경로2.2.3. 연결 그래프2.2.4. 트리2.2.5. n분 그래프
2.2.5.1. 이분 그래프
2.2.6. 매칭
2.3. 성질
2.3.1. 그래프의 동형2.3.2. 그래프와 동형인 자료구조
2.3.2.1. 인접목록2.3.2.2. 인접행렬2.3.2.3. 결합행렬
2.3.3. 연결의 정도2.3.4. 평면성
3. 관련 문서
3.1. 관련 문제 및 알고리즘
4. 둘러보기

1. 개요

그래프는 그래프 이론에서 다루는 수학적 대상이다. 그래프는 정점(또는 꼭짓점)과, 두 정점을 연결하는 변(또는 모서리)들로 구성된다. 일반적으로 정점은 점으로 표현하고 변은 선분으로 표현한다. 변에 방향을 부여한 그래프를 유향 그래프(Directed graph)라고 하며, 이 경우 변을 화살표로 표현한다. 위의 그림 1은 그래프를 도식화한 예시이다.

예를 들어 도시를 정점으로 생각하고 도시 사이를 잇는 도로를 변으로 생각하면 그래프는 곧 하나의 간략화된 지도가 된다. 위의 그림에서 1~6번 원이 도시고 연결선이 도로인 셈. 이렇게 그래프는 도시를 정점으로, 도로를 변으로 보는 것처럼 나타낼 수 있기 때문에 두 지점 간의 최단 경로(또는 가장 저렴한 경로)를 구하는 등의 문제에서 널리 이용된다. 그래프는 도시-도로뿐만 아니라 컴퓨터 통신망, 소셜 네트워크 서비스에서의 친구관계 등등 여러 상황을 모델링 할 수 있어 많은 분야에서 널리 사용된다. 예를 들어 어떤 웹 페이지를 정점으로 하고 페이지에 달린 링크들을 다른 페이지로 가는 변이라고 보면, 나무위키 역시 하나의 거대한 유향그래프라고 볼 수 있다.

그림 1의 그래프에서는 2,3,4,5번 정점들이 서로 연결되어 하나의 순환을 이룬다. 다시 말해서 2번 정점에서 출발하여 3,4,5번 정점을 순서대로 하나씩만 거친 후 다시 2번에 도착할 수 있는데, 이러한 구조를 순환 또는 사이클이라고 한다. 한편 이렇게 순환을 가지지 않는 연결된 그래프를 트리(그래프)라고 한다.

순수수학에서는 수학자 레온하르트 오일러가 한붓그리기 문제, 즉 쾨니히스베르크 다리 건너기 문제를 푼 것을 그래프 이론의 시작으로 보고 있다. 이 외에도 그래프 이론에서 대중에게 비교적 친숙한 문제로는 4색정리해밀턴 회로[1] 등이 있을 것이다.

과거 2007 개정 교육과정까지 고등학교 수학에 등장했던 '행렬과 그래프'라는 단원에서의 그래프는 해석학적인 그래프가 아니라 바로 이 그래프를 뜻한다.

2. 용어와 개념

2.1. 정의

그래프 이론의 초기에는 그래프가 한 종류였지만, 현대에 들어 컴퓨터공학, 전자공학 등의 발전으로 인해 여러 변형이 생겼다.

2.1.1. 그래프

그래프(graph) [math(G)]는 정점(vertex)[2]의 집합 [math(V=V(G))][3](edge)[4]의 집합 [math(E=E(G))]의 순서쌍 [math(\displaystyle G=(V, E) )]으로 정의된다. 여기서 변의 원소 [math(e \in E)]는 두 개의 정점으로 구성된 집합이다. 예를 들어 두 정점 [math(u,v)]를 잇는 변은 [math(e = \{ u, v \})]로 정의되며, [math(uv)]로 표기한다. 이 때 [math(u,v)]를 [math(e)]의 끝점(endpoint)이라 하고, [math(u)]와 [math(v)]는 서로 이웃한다(adjacent)고 하며 [math(u)]를 [math(v)]의 이웃(neighbor)이라고 한다. 그리고 '[math(e)]는 [math(u)](또는 [math(v)])와 붙어있다(incident)'고 표현하고 '[math(e)]가 [math(u,v)]를 연결한다(connect)'고 말한다.

[math(V)]가 유한인 그래프를 유한 그래프(finite graph)라고 하며, 유한이 아닌 그래프를 무한 그래프(infinite graph)라고 한다. 일반적으로 별도의 서술이 없이 그래프라 하면 유한 그래프를 의미한다.

일반적으로 그림에서 정점은 점이나 원으로 표현되고, 변은 두 꼭짓점을 잇는 선으로 표현된다. 예를 들어, 그림 1의 그래프를 [math(G = (V, E))]라 했을 때 꼭짓점의 집합 [math(V)]와 변의 집합 [math(E)]를 엄밀하게 정의하면 다음과 같다.

[math(\displaystyle \begin{aligned} &V = \{1, 2, 3, 4, 5, 6\} \\ &E = \left\{ \{1, 2\}, \{1, 5\}, \{2, 3\}, \{2, 5\}, \{3, 4\}, \{4, 5\}, \{4, 6\} \right\} \end{aligned} )]

2.1.1.1. 유향그래프
그래프의 정의에서, [math(e \in E)]를 집합이 아닌 순서쌍 [math(\displaystyle e \equiv (u,v))]와 같이 정의한 그래프를 유향그래프(directed graph, digraph)라고 한다. 이때 [math(e)]는 방향변(방향모서리, directed edge 또는 arc)이라고 한다. 이때, [math(u)]는 [math(e)]의 시점(tail), [math(v)]는 [math(e)]의 종점(head)이라 하며, '[math(e)]는 [math(u)]에서 시작하여 [math(v)]에서 끝난다', 또는 '[math(u)]에서 [math(v)]로 간다'와 같이 표현한다. 도식화하는 경우, 유향변은 흔히 시점에서 종점으로 향하는 화살표(arrow)로 표현된다.

한편, 유향그래프가 아닌 그래프를 무향그래프(비방향성 그래프, undirected graph)라 한다. 일반적으로 그래프라고 하면 무방향그래프를 의미한다.

유향그래프는 무향그래프와 달리 두 정점 사이의 단방향적인 관계를 표현할 수 있다.
2.1.1.2. 다중그래프
다중그래프(multigraph)는 두 꼭짓점을 연결하는 여러 개의 변이나, 정점에서 출발해 자기 자신으로 돌아오는 루프를 허용하는 그래프이다. 즉 다중그래프는 서로소인 정점 집합 [math(V)]과 변 집합 [math(E)]의 순서쌍 [math((V,E))]와 함께 다음의 함수 [math(\partial)]을 가지는 집합이다.

[math(\partial : E \to S^2(V))]

여기서 공역은 [math(S^2(V) = \left\{ \left\{ u, v \right\}|u, v \in V \right\})]으로, [math(V\cup\binom{V}{2})]와 같다. 즉, [math(\partial)]은 각각의 변마다 두 끝점 또는 하나의 정점을 정해주는 함수이다.

이전의 정의와는 달리, [math(E)]의 원소, 즉 변은 끝점을 이용하여 정의되지 않는다. 그 대신 어떤 변이 어떤 두 끝점과 연결되는지를 함수 [math(\partial)]로 정의하는 것이다. 예를 들어 [math(\partial e_1 = \{u, v\})]라면 변 [math(e_1)]의 끝점은 [math(u)]와 [math(v)]라는 뜻이다. [math(\partial e = \{u, v\})]가 되는 변 [math(e)]는 [math(e_1)] 이외에도 여러 개가 있을 수 있는데, 이 경우 두 정점은 여러 변과 연결되어 있다고 할 수 있는 것이다.

하나의 정점에서 출발해 자기 자신으로 돌아오는 변을 루프(loop), 또는 고리라 한다. 즉 루프는 다중 그래프에서 [math(\partial)]의 값이 하나의 원소로 정해지는 변이다.

다중그래프가 아닌 그래프를 단순 그래프(simple graph)라 하며, 문맥에 따라 다르지만 일반적으로 그래프라 하면 단순 그래프를 의미한다.

다중그래프는 단순그래프와 달리 두 정점 사이의 여러 관계를 표현할 수 있다. 가장 자주 쓰이는 예시는 회로 문제, 특히 한붓그리기 문제이다. 일반적인 한붓그리기에선 두 정점 사이에 하나 이상의 변이 존재할 수 있지만, 한번 지나간 변은 다시 지나갈 수 없다.
2.1.1.3. 유향 다중그래프
다중 그래프에도 변의 방향을 적용하는 방법을 생각할 수 있다. 그러나 다중 그래프에서는 변의 두 끝점을 [math(E)]의 정의가 아닌 새로운 함수 [math(\partial)]를 이용해 결정했으므로, 유향 다중그래프(directed multigraph)는 다음과 같이 [math(\partial)]의 공역을 고쳐 새롭게 정의해야 한다.

[math(\displaystyle \partial : E \to V^2)]

여기서 [math(V^2 = V \times V = \left\{ \left( u, v \right)|u, v \in V \right\})]이다. 즉, 유향 그래프와 마찬가지로 두 꼭짓점들의 집합을 순서쌍으로 바꾼 것이다.
2.1.1.4. 가중 그래프
가중 그래프(weighted graph)는 각각의 변에 가중치(weight)라 불리는 값을 대응한 그래프이다. 엄밀하게는 가중치 함수 [math(W : E \to \mathbb{R})]를 추가한 그래프로 정의할 수 있다.

가중치는 그래프 모델이 쓰이는 상황에 따라 다르게 정의되어 다양하게 활용될 수 있다. 예를 들어 비행기의 항로를 그래프로 모델링한다면, 운항 거리, 시간, 항공비 등을 가중치로 고려할 수 있는데, 최단 경로 문제의 풀이법을 이용하면 '목적지까지 가장 빨리, 비용이 적게 도착할 수 있는 항공편은?' 같은 질문에 답할 수 있게 된다.

2.1.2. 기본 개념

2.1.2.1. 이웃
정점 [math(v)]의 이웃(neighborhood, neighbor) 또는 인접(adjacent)이란 [math(v)]와 이웃한 정점들의 집합이다. 기호로는 [math(N(v))]와 같이 쓴다. 예를 들어 단순 무향 그래프인 경우에는 다음과 같다.

[math(\displaystyle N(v) = \left\{u \in V | \left\{u, v \right\} \in E \right\})]


정점의 집합 [math(A)]에 대해서, [math(A)]의 이웃 [math(N(A))]는 모든 [math(v \in A)]의 이웃의 합집합 [math(\displaystyle N(A)=\bigcup_{v \in A}N(v))]이다.
2.1.2.2. 차수
무향 그래프에서 정점 [math(v)]의 차수(degree)는 해당 정점에 연결된 모서리의 끝점(endpoint) 수를 의미한다. 모서리가 아니라 끝점의 갯수를 세는 것이기에, 고리(loop)를 허용하는 경우 정점과 두 번 접하는 것이므로 두 개로 센다.

기호로는 [math(\operatorname{deg}(v))] 또는 [math(d(v))]라 쓰며, 엄밀하게는 다음과 같이 정의한다.

[math(\displaystyle \operatorname{deg}(v) \equiv \left| N(v) \right| + 2\left|\left\{ \{v\} \in E \right\}\right| )]

2.1.2.2.1. 입력차수와 출력차수
유향 그래프에서는 변의 방향에 따라 차수를 구분할 수 있으며, 정점 [math(v)]를 향하는 모서리의 갯수를 입력차수(in-degree) [math(\operatorname{deg}^{-}(v))], 정점 [math(v)]에서 나가는 모서리의 갯수를 출력차수(out-degree) [math(\operatorname{deg}^{+}(v))]라 한다.

[math(\displaystyle \begin{aligned} \operatorname{deg}^{-}(v) \equiv& \left|\left\{ u \in V | (u, v) \in E \right\}\right| \\ \operatorname{deg}^{+}(v) \equiv& \left|\left\{ u \in V | (v, u) \in E \right\}\right| \end{aligned} )]

다른 말로, 입력차수와 출력차수는 각각 [math(v)]를 종점과 시점으로 갖는 모서리의 수이다. 무향 그래프와 같이 고리(loop)는 입, 출력차수 모두에 1씩 영향을 미친다. 입력차수와 출력차수의 합은 항상 차수와 같다.

2.2. 구조 및 분류

그래프 [math(G)]의 부분그래프(subgraph) [math(H)]는 [math(V(H) \subset V(G))]이고 [math(E(H) \subset E(G))]인 그래프로 정의한다. [math(V(H)=V(G))]인 경우 [math(H)]를 [math(G)]의 생성그래프(spanning subgraph)라고 한다.

그래프 [math(G)]의 정점의 부분집합 [math(U\subset G)]에 대하여, [math(U)]의 정점들을 연결하는 [math(G)]의 모든 변들로 생성되는 그래프를 유도된 부분그래프(induced subgraph)라고 하며 [math(G[U])]로 표기한다. 즉, [math(G[U])]는 정점 집합 [math(U)]와 변 집합 [math(\{e\in E(G):e\subset U\})]를 가지는 그래프이다.

그래프 [math(G)]의 여 그래프(complement graph) [math(\bar{G})]는 [math(G)]의 이어지지 않은 모든 변들을 변으로 가지는 그래프이다. 즉 [math(\bar{G}=(V,\binom{V}{2}\setminus E))]이다.[5]

2.2.1. 완전 그래프

모든 서로 다른 정점끼리 연결된 그래프를 완전 그래프(complete graph)라고 한다. 정점이 [math(n)]개이면 n-완전 그래프(n-complete graph)라 하며, [math(K_n)]으로 표기한다. 이때 변의 개수는 [math({}_n{\rm C}_2 = \dfrac{n(n-1)}2)]개이며, 모든 정점의 차수는 항상 [math(n-1)]라는 성질이 있다.

완전 그래프가 아닌 그래프, 즉, 최소 한 쌍의 서로 연결되지 않은 꼭짓점 쌍이 존재하는 그래프를 불완전 그래프(incomplete graph)라 한다.

2.2.2. 보행, 사이클, 경로

서로 인접한 변들의 나열을 보행(walk)이라고 한다. 즉 보행 [math(v_1v_2\cdots v_n)]은 정점 [math(v_i)]와 변 [math(v_iv_{i+1}\in E(G))]들의 나열이다. 이때 변의 수 [math(n-1)]를 보행의 길이(length)라고 한다. 보행은 같은 정점 또는 같은 변을 여러 번 거칠 수 있다. 보행의 시작점과 끝점이 같으면 닫혀있다(closed)고 한다.
중복된 변을 가지지 않는 보행을 트레일(trail)이라고 하며, 닫힌 트레일을 회로(circuit)이라고 한다.

모든 정점이 다른 보행을 경로(path)라고 한다. 즉 경로는 같은 정점을 다시 거치지 않는 변들의 나열이다. 길이가 [math(n)]인 경로를 일반적으로 [math(P_n)]으로 표기한다.

끝점을 제외한 모든 정점이 다른 회로를 사이클(cycle)이라고 한다. 즉 사이클은 같은 정점을 다시 거치지 않으면서 시작점과 끝점이 같은 변들의 나열이다. 길이가 [math(n)]인 사이클을 일반적으로 [math(C_n)]으로 표기한다.

2.2.3. 연결 그래프

임의의 두 정점을 변들로 연결할 수 있는 그래프를 연결 그래프(connected graph)라고 한다. 즉 연결 그래프는 임의의 두 정점 [math(u,v\in V(G))]에 대해 [math(u)]에서 [math(v)]로 가는 경로가 존재하는 그래프이다. 주어진 그래프의 연결 부분 그래프가 더 이상 정점이나 변을 추가하면 연결 그래프가 아니게 될 때 이 부분 그래프를 그래프의 성분(component) 또는 연결 성분이라고 부른다. 즉, 그래프의 성분은 포함 관계에 대해 극대인 연결 그래프이다.

2.2.4. 트리

사이클을 부분 그래프로 가지지 않는 그래프를 비순환 그래프(acyclic graph) 또는 포레스트(forest)라고 한다.

비순환 연결 그래프를 트리(tree) 또는 나무라고 한다. 트리는 다음 방식들로 정의할 수도 있으며, 모두 동치인 조건들이다.
(1) 임의의 두 정점들 사이에 경로가 유일하게 존재한다.
(2) 임의의 변을 추가했을 때 사이클이 생긴다.

2.2.5. n분 그래프

정점 집합이 서로소인 n개의 부분집합들로 분할될 수 있는 그래프를 n분 그래프(n-partite graph)라고 한다.
2.2.5.1. 이분 그래프
서로소인 두 정점 부분집합 [math(X)], [math(Y)]들 사이를 연결하는 변만을 변으로 가지는 그래프를 이분 그래프(bipartite graph)라 한다. [math(X,Y)]-이분 그래프라고도 한다. 즉 이분 그래프는 n분 그래프에서 n=2인 경우이다.
이분 그래프의 판별법은 두 가지 색으로 모든 점들을 색칠하는 건데, 인접한 점들은 다른 색만 사용하는 것이다. 만약 색칠을 하다 인접한 점끼리 반드시 같은 색으로 칠해야만 하는 상황이 온다면 해당 그래프는 이분 그래프가 아니다. 조금 더 간편한 방법으로는 이분 그래프 내부에 cycle이 짝수 개의 edge를 가지고 있으면 이는 이분 그래프가 되기 위한 필요충분조건이 된다. 표기법은 [math(|V_1|=m, |V_2|=n)]이라 했을 때 [math(K_{m,n})]. 이를 보다 확장시켜서 [math(n)]분 그래프라는걸 생각할 수 있는데, 표기법은 마찬가지로 각 정점 집합의 분할의 위수를 아래첨자로 나열한다.

2.2.6. 매칭

매칭(matching)이란 서로 연결되지 않은 변들의 집합을 뜻한다. 한 그래프에서 얻을 수 있는 매칭 중 제일 원소의 개수가 많은 매칭을 최대 매칭이라 하며, 모든 정점들을 포함하는 매칭을 완전 매칭(perfect matching)이라 한다.

홀의 정리(Hall's theorem)는 그래프 [math(G)]가 완전 매칭을 가질 필요충분조건에 대한 정리이다. 이 정리에 의하면, [math(X,Y)]-이분 그래프 [math(G)]가 완전 매칭을 가질 필요충분조건은 [math(X)]의 모든 부분집합 [math(A)]에 대해서 [math(N(A))]의 크기가 [math(A)]의 크기 이상인 것이다.

2.3. 성질

2.3.1. 그래프의 동형

두 그래프 [math(G_1=(V_1,E_1))]과 [math(G_2=(V_2,E_2))]가 있을 때 [math(V_1)]으로부터 [math(V_2)]의 일대일대응이 존재하고, 그 대응에 의해서 [math(E_1)]이 [math(E_2)]로 대응되는 경우 두 그래프가 동형(isomorphism)이라고 한다.

2.3.2. 그래프와 동형인 자료구조

컴퓨터에서 그래프를 수학적인 정의 그대로 구현하는 것은 복잡하기 때문에 그래프를 다룰 때는 동형인 다른 자료 구조로 표현하여 다루는 경우가 많다.
2.3.2.1. 인접목록
인접목록(adjacent list)은 단순하게 각 정점에 대해 자신과 연결된 정점들을 나열한 목록이다. 예를 들면 [math(a, b, c, d, e)]라는 정점들이 있을 때 [math(a: [b, d, e])], [math(b :[a, c])]와 같이 단순하게 나열한 것이다.

하지만 인접목록으로는 유용한 성질을 유도하기가 어렵다.
2.3.2.2. 인접행렬

[math(A = \begin{bmatrix} 0&1&0&0&1&0 \\ 1&0&1&0&1&0 \\ 0&1&0&1&0&0 \\ 0&0&1&0&1&1 \\ 1&1&0&1&0&0 \\ 0&0&0&1&0&0 \end{bmatrix})]


위는 그림 1의 그래프에 대한 인접행렬이다.

인접행렬(adjacency matrix)은 각 행 번호, 열 번호마다 정점들을 같은 순서대로 대응시키고, 각 성분들이 정점 사이의 연결 정도를 나타내도록 만든 행렬이다. 기본적으로 단순 그래프 [math(G = (V, E))]에 대한 인접행렬 [math(A)]은 다음과 같은 [math(|V| \times |V|)] 크기의 행렬로 정의된다.


[math(A_{ij} = \begin{cases}1 && \left(\left\{ v_i, v_j \right\} \in E \right) \\ 0 && (\rm{otherwise}) \end{cases})]


다중그래프의 인접행렬의 경우에는 0, 1 대신 모서리의 수를 기입하면 되며 고리(loop)의 경우에는 대각성분에 2를 추가해주면 된다. 방향성 그래프의 경우에는 각 변의 시작점을 행 번호에, 끝점에 열 번호에 대응시키면 된다.

인접행렬은 인접목록과 비교했을 때 조금 더 유용한 성질들이 있다.
  • 단순그래프의 인접행렬은 항상 대칭이고, 대각성분이 0이다.
  • 각 정점 [math(v_i)]에 대응되는 [math(i)]행의 숫자의 합은 [math(v_i)]의 입력차수 [math(\operatorname{deg^-}(v_i))], [math(v_j)]에 대응되는 [math(j)]열의 숫자의 합은 [math(v_j)]의 출력차수 [math(\operatorname{deg^+}(v_j))]와 같다. 무방향 그래프의 경우 둘은 그 정점의 차수로 같다.
  • 행렬에 있는 모든 1의 개수를 2로 나누면 모서리의 개수가 된다. (악수의 정리를 생각해보자)
  • 인접행렬 [math(A)]에 대해 [math(A^n)]의 [math(i)]열 [math(j)]행의 값은 꼭짓점 [math(i)]에서 꼭짓점 [math(j)]로 이어지는 길이 [math(n)]의 경로의 수와 같다. 이를 이용해 길이를 아는 경로의 수를 보다 쉽게 계산할 수 있다.
파일:상세 내용 아이콘.svg   자세한 내용은 인접행렬 문서
#!if (문단 == null) == (앵커 == null)
를
#!if 문단 != null & 앵커 == null
의 [[인접행렬#s-|]]번 문단을
#!if 문단 == null & 앵커 != null
의 [[인접행렬#|]] 부분을
참고하십시오.
2.3.2.3. 결합행렬
결합행렬(incidence matrix)은 각 행 번호에는 정점들을 대응시키고, 각 열 번호에는 모서리들을 대응시킨 다음, 모서리가 정점을 연결할 때 1을 쓰고 아니면 0을 써서 만드는 행렬이다.

이 경우에도 1의 합을 2로 나누면 모서리의 개수가 나오며, 각 열마다 오로지 두개씩의 1만이 나온다. 이는 당연한 건데, 각 모서리는 두개의 끝점 이상을 정의상 가질 수 없기 때문이다. 또한 행의 모든 1을 더하면 차수를 얻을 수 있다. 단 루프가 있는 경우에는 1이 하나만 있을수도 있다.

이는 gilbert strang의 선형대수 교재에서도 사용되는 방식으로, 이를 통해 여러 대상들 사이의 에너지 교환을 행렬로 표현하여 전체 시스템의 변화를 기술하는데에 응용할 수도 있다.

2.3.3. 연결의 정도

연결된 그래프의 연결이 어느 정도로 강한지를 정의할 수 있는 방법은 무엇일까. 이는 얼마나 많은 점 또는 모서리를 제거해야 연결이 사라지는지로 나타낼 수 있다. 이러한 점들의 집합을 separating set이라고 부르며, cut vertex는 오로지 하나의 vertex만을 지니는 separating set을 뜻한다. 이때 연결그래프 [math(G)]의 연결성을 [math(\kappa \left(G\right))]라고 하는데 이는 separating set의 cardinality의 최솟값을 의미한다. 만약 [math(\kappa \left(G\right) \ge k)]면 G을 [math(k)]-connected하다고 부른다. 즉 점을 하나만 제거해도 연결성이 제거된다면 1-connected, 2개를 제거해야 한다면 2-connected라고 하는 것.

이는 당연히 모서리를 통해서도 정의가 가능한데, 모서리의 경우에는 disconnecting set이라 하며, cutset은 disconnecting set의 극소이며, bridge는 하나의 모서리를 가진 cutset을 뜻한다. 여기서 극소라 하면, 어떤 그래프에서 몇몇 모서리만을 지정하고, 이 모서리중에서 그래프를 분리시킬 수 있는 최소의 모서리들을 뜻하기 때문에, 전체 그래프에 해당되는 개념이 아니다. 여기서는 연결성을 [math(\lambda \left(G \right))]라고 하며, [math(\lambda \left(G \right) \ge k)]면 [math(G)]를 [math(k)]-edge-connected이라고 정의한다.

2.3.4. 평면성

그래프의 모든 변이 평면상에서 서로 교차하지 않는 위상동형 그래프를 그릴 수 있을 때, 평면성을 가진다고 한다.
해당 그래프 [math(G)]가 어떤 그래프냐에 따라서 평면성을 판정하는 방법이 달라진다.
  • [math(G)]가 연결 단순 그래프이고, 그래프의 차수[6]가 [math(d\left(G\right)\geq 3)]일 때
    [math(G)]가 평면 그래프 [math(\displaystyle \Rightarrow v\geq 2+\frac{e}{3})]
  • [math(G)]가 연결 이분 단순 그래프이고, 그래프의 차수가 [math(d\left(G\right)\geq 3)]일 때
    [math(G)]가 평면 그래프 [math(\displaystyle \Rightarrow v\geq 2+\frac{e}{2})]
  • [math(G)]가 연결 단순 그래프라면
    [math(G)]가 평면 그래프 [math(\displaystyle \Rightarrow \forall e_i \in E, d\left(e_i\right)\leq 5)]

쿠라토프스키 정리(Kuratowski's Theorem)에 의해서, 평면 그래프는 [math(K_5)]와 [math(K_{3,3})]의 세분(subdivision)[7]을 부분그래프로 가지지 않는다.

바그너의 정리(Wagner's theorem)에 의해서, 평면 그래프는 [math(K_5)]와 [math(K_{3,3})]을 마이너(Graph Minor)로 가지지 않는다.

3. 관련 문서

3.1. 관련 문제 및 알고리즘

4. 둘러보기

[[컴퓨터공학|'''컴퓨터 과학 및 공학
{{{#!wiki style="font-family: Times New Roman, serif; display: inline;"
]]
{{{#!wiki style="margin: 0 -10px -5px; min-height:calc(1.5em + 5px)"
{{{#!folding [ 펼치기 · 접기 ]
{{{#!wiki style="margin: -5px -1px -11px"
<bgcolor=#1282d7,#1282d7> 기반 학문 수학(해석학 · 이산수학 · 수리논리학 · 선형대수학 · 미적분학 · 미분방정식 · 대수학(환론 · 범주론) · 정수론) · 이론 컴퓨터 과학 · 암호학 · 전자공학 · 언어학(음운론 · 형태론 · 통사론 · 의미론 · 화용론) · 인지과학
하드웨어 SoC · CPU · GPU(그래픽 카드 · GPGPU) · ROM · RAM · SSD · HDD · 참조: 틀:컴퓨터 부품
기술 기계어 · 어셈블리어 · 바이오스 · 절차적 프로그래밍 · 객체 지향 프로그래밍 · 함수형 프로그래밍 · 해킹 · ROT13 · 일회용 비밀번호 · 사물인터넷 · 와이파이 · GPS · 임베디드 · 인공신경망 · OpenGL · EXIF · 마이크로아키텍처 · ACPI · UEFI · LinuxBoot · gRPC · 리버스 엔지니어링 · HCI · UI · UX · 대역폭 · DBMS · NoSQL · 해시(SHA · 브루트 포스 · 레인보우 테이블 · salt · 암호화폐) · RSA 암호화 · 하드웨어 가속
연구 및 기타 논리 회로(보수기 · 가산기 · 논리 연산 · 불 대수 · 플립플롭) · 정보이론 · 임베디드 시스템 · 운영체제(멀티태스킹 · 프로세스 스케줄링 · 데드락 · 식사하는 철학자 문제 · 뮤텍스 · 세마포어 · 인터럽트) · 데이터베이스 · 컴퓨터 언어 · 프로그래밍 언어{컴파일러(어셈블러 · JIT) · 인터프리터 · 유형 이론 · 어휘 분석 · 파싱 · 링커 · 난해한 프로그래밍 언어} · 마크업 언어 · 메타데이터 · 기계학습 · 빅데이터 · 폰노이만 구조 · 양자컴퓨터 · 행위자 모델 · 인코딩(유니코드 · MBCS) · 네트워크(네트워크 포트) · 컴퓨터 보안 · OCR · 슈퍼컴퓨터 · 튜링 머신 · FPGA · 딥러닝 · 컴퓨터 구조론 · 컴퓨터 비전 · 컴퓨터 그래픽스 · 인공지능 · 시간 복잡도(최적화) · 소프트웨어 개발 방법론 · 디자인 패턴 · 정보처리이론 · 재귀 이론 · 자연어 처리(기계 번역 · 음성인식) · 버전 (버전 관리 시스템) · 난수생성 · 놀람 최소화 원칙 · 프레임워크 · 라이브러리 · 모듈 · API · ABI · 이진 탐색
}}}}}}}}} ||


[1] 모든 정점들을 한 번씩만 지나는 경로[2] 또는 꼭짓점. 공학계열에서는 '노드(node)'라고 부르기도 한다.[3] 보통 따로 명시되지 않는 이상 [math(V \neq \varnothing)]이다.[4] 또는 모서리[5] [math(\binom{V}{2})]는 [math(V)]의 서로 다른 원소 2개로 구성된 모든 집합들을 원소로 가지는 집합족이다.[6] 해당 그래프의 모든 닫힌 도형의 변의 수를 합한 것. 평면 그래프라면 변의 수의 2배가 된다. 이는 평면그래프는 구면상에서 정의되기 때문으로, 그래프 외부 역시 도형으로 취급하기 때문.[7] 주어진 그래프의 선 위에 임의로 점을 찍은 그래프.


#!if version2 == null
{{{#!wiki style="border:1px solid gray;border-top:5px solid gray;padding:7px;margin-bottom:0px"
[[크리에이티브 커먼즈 라이선스|[[파일:CC-white.svg|width=22.5px]]]] 이 문서의 내용 중 전체 또는 일부는 {{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/그래프|그래프]]}}}{{{#!if external != "o"
[[그래프]]}}}}}} 문서의 {{{#!if uuid == null
'''uuid not found'''}}}{{{#!if uuid != null
[[https://namu.wiki/w/그래프?uuid=974cf9dc-6912-4fa1-9139-b06586e78961|r69]]}}} 판{{{#!if paragraph != null
, [[https://namu.wiki/w/그래프?uuid=974cf9dc-6912-4fa1-9139-b06586e78961#s-3|3번 문단]]}}}에서 가져왔습니다. [[https://namu.wiki/history/그래프?from=69|이전 역사 보러 가기]]}}}
#!if version2 != null
{{{#!wiki style="display: block;"
{{{#!wiki style="border:1px solid gray;border-top:5px solid gray;padding:7px;margin-bottom:0px"
[[크리에이티브 커먼즈 라이선스|[[파일:CC-white.svg|width=22.5px]]]] 이 문서의 내용 중 전체 또는 일부는 다른 문서에서 가져왔습니다.
{{{#!wiki style="text-align: center"
{{{#!folding [ 펼치기 · 접기 ]
{{{#!wiki style="text-align: left; padding: 0px 10px"
{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/그래프|그래프]]}}}{{{#!if external != "o"
[[그래프]]}}}}}} 문서의 {{{#!if uuid == null
'''uuid not found'''}}}{{{#!if uuid != null
[[https://namu.wiki/w/그래프?uuid=974cf9dc-6912-4fa1-9139-b06586e78961|r69]]}}} 판{{{#!if paragraph != null
, [[https://namu.wiki/w/그래프?uuid=974cf9dc-6912-4fa1-9139-b06586e78961#s-3|3번 문단]]}}} ([[https://namu.wiki/history/그래프?from=69|이전 역사]])
{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid2 == null
'''uuid2 not found'''}}}{{{#!if uuid2 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph2 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]]){{{#!if version3 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid3 == null
'''uuid3 not found'''}}}{{{#!if uuid3 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph3 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version4 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid4 == null
'''uuid4 not found'''}}}{{{#!if uuid4 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph4 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version5 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid5 == null
'''uuid5 not found'''}}}{{{#!if uuid5 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph5 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version6 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid6 == null
'''uuid6 not found'''}}}{{{#!if uuid6 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph6 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version7 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid7 == null
'''uuid7 not found'''}}}{{{#!if uuid7 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph7 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version8 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid8 == null
'''uuid8 not found'''}}}{{{#!if uuid8 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph8 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version9 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid9 == null
'''uuid9 not found'''}}}{{{#!if uuid9 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph9 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version10 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid10 == null
'''uuid10 not found'''}}}{{{#!if uuid10 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph10 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version11 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid11 == null
'''uuid11 not found'''}}}{{{#!if uuid11 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph11 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version12 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid12 == null
'''uuid12 not found'''}}}{{{#!if uuid12 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph12 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version13 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid13 == null
'''uuid13 not found'''}}}{{{#!if uuid13 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph13 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version14 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid14 == null
'''uuid14 not found'''}}}{{{#!if uuid14 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph14 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version15 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid15 == null
'''uuid15 not found'''}}}{{{#!if uuid15 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph15 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version16 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid16 == null
'''uuid16 not found'''}}}{{{#!if uuid16 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph16 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version17 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid17 == null
'''uuid17 not found'''}}}{{{#!if uuid17 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph17 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version18 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid18 == null
'''uuid18 not found'''}}}{{{#!if uuid18 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph18 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version19 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid19 == null
'''uuid19 not found'''}}}{{{#!if uuid19 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph19 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version20 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid20 == null
'''uuid20 not found'''}}}{{{#!if uuid20 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph20 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version21 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid21 == null
'''uuid21 not found'''}}}{{{#!if uuid21 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph21 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version22 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid22 == null
'''uuid22 not found'''}}}{{{#!if uuid22 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph22 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version23 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid23 == null
'''uuid23 not found'''}}}{{{#!if uuid23 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph23 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version24 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid24 == null
'''uuid24 not found'''}}}{{{#!if uuid24 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph24 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version25 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid25 == null
'''uuid25 not found'''}}}{{{#!if uuid25 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph25 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version26 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid26 == null
'''uuid26 not found'''}}}{{{#!if uuid26 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph26 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version27 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid27 == null
'''uuid27 not found'''}}}{{{#!if uuid27 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph27 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version28 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid28 == null
'''uuid28 not found'''}}}{{{#!if uuid28 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph28 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version29 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid29 == null
'''uuid29 not found'''}}}{{{#!if uuid29 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph29 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version30 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid30 == null
'''uuid30 not found'''}}}{{{#!if uuid30 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph30 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version31 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid31 == null
'''uuid31 not found'''}}}{{{#!if uuid31 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph31 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version32 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid32 == null
'''uuid32 not found'''}}}{{{#!if uuid32 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph32 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version33 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid33 == null
'''uuid33 not found'''}}}{{{#!if uuid33 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph33 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version34 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid34 == null
'''uuid34 not found'''}}}{{{#!if uuid34 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph34 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version35 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid35 == null
'''uuid35 not found'''}}}{{{#!if uuid35 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph35 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version36 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid36 == null
'''uuid36 not found'''}}}{{{#!if uuid36 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph36 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version37 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid37 == null
'''uuid37 not found'''}}}{{{#!if uuid37 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph37 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version38 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid38 == null
'''uuid38 not found'''}}}{{{#!if uuid38 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph38 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version39 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid39 == null
'''uuid39 not found'''}}}{{{#!if uuid39 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph39 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version40 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid40 == null
'''uuid40 not found'''}}}{{{#!if uuid40 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph40 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version41 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid41 == null
'''uuid41 not found'''}}}{{{#!if uuid41 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph41 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version42 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid42 == null
'''uuid42 not found'''}}}{{{#!if uuid42 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph42 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version43 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid43 == null
'''uuid43 not found'''}}}{{{#!if uuid43 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph43 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version44 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid44 == null
'''uuid44 not found'''}}}{{{#!if uuid44 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph44 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version45 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid45 == null
'''uuid45 not found'''}}}{{{#!if uuid45 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph45 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version46 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid46 == null
'''uuid46 not found'''}}}{{{#!if uuid46 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph46 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version47 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid47 == null
'''uuid47 not found'''}}}{{{#!if uuid47 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph47 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version48 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid48 == null
'''uuid48 not found'''}}}{{{#!if uuid48 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph48 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version49 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid49 == null
'''uuid49 not found'''}}}{{{#!if uuid49 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph49 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}{{{#!if version50 != null
{{{#!wiki style="display: block;"

{{{#!wiki style="display: inline-block"
{{{#!if external == "o"
[[https://namu.wiki/w/|]]}}}{{{#!if external != "o"
[[]]}}}}}} 문서의 {{{#!if uuid50 == null
'''uuid50 not found'''}}}{{{#!if uuid50 != null
[[https://namu.wiki/w/?uuid=|r]]}}} 판{{{#!if paragraph50 != null
, [[https://namu.wiki/w/?uuid=#s-|번 문단]]}}} ([[https://namu.wiki/history/?from=|이전 역사]])}}}}}}}}}}}}}}}}}}}}}