728x90
반응형
##인접행렬 그래프 dfs 탐색
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
#define _CRT_SECURE_NO_WARNINGS
#include<iostream>
#include<cstdio> // c 문법 헤더파일
#include<vector> // 동적배열 라이브러리
using namespace std; // cin,cout 편하게 사용 라이브러리
int visit[7];
vector<int> adj_arr[8]; // 인접행렬
// dfs 종료조건 방법1 : 재귀종료조건
void dfs(int x) {
if (visit[x] == 1) { // 방문했으면 반환
return;
}
visit[x] = 1; // 방문처리
cout << x << '\n';
for (int i = 0; i < adj_arr[x].size(); i++) { // 방문 노드의 인접노드 탐색
int y = adj_arr[x][i];
dfs(y);
}
}
// dfs 종료조건 방법2: 탐색 반복문 안에서 조건문
void dfs2(int x) {
visit[x] = 1; // 방문처리
cout << x << '\n';
for (int i = 0; i < adj_arr[x].size(); i++) { // 방문 노드의 인접노드 탐색
int y = adj_arr[x][i];
if (visit[y] != 1) { dfs(y); } // 방문하지 않았으면 방문
}
}
int main()
{
// IO 속도 향상
ios_base::sync_with_stdio(0);
cin.tie(NULL); cout.tie(NULL);// 입출력 시간 단축
// 양방향 그래프 연결
// 1과 2을 연결합니다.
adj_arr[1].push_back(2);
adj_arr[2].push_back(1);
// 1과 3를 연결합니다.
adj_arr[1].push_back(3);
adj_arr[3].push_back(1);
// 2과 3를 연결합니다.
adj_arr[2].push_back(3);
adj_arr[3].push_back(2);
// 2과 4을 연결합니다.
adj_arr[2].push_back(4);
adj_arr[4].push_back(2);
// 2과 5를 연결합니다.
adj_arr[2].push_back(5);
adj_arr[5].push_back(2);
// 3와 6를 연결합니다.
adj_arr[3].push_back(6);
adj_arr[6].push_back(3);
// 3와 7을 연결합니다.
adj_arr[3].push_back(7);
adj_arr[7].push_back(3);
// 4와 5를 연결합니다.
adj_arr[4].push_back(5);
adj_arr[5].push_back(4);
// 6과 7을 연결합니다.
adj_arr[6].push_back(7);
adj_arr[7].push_back(6);
dfs(1); // 1 노드부터 깊이우선 탐색
//dfs2(1); // 1 노드부터 깊이우선 탐색
return 0;
}
|
cs |
반응형