본문 바로가기

Algorithm_몰랐던 함수 및 개념/DFS

DFS 기초 동빈나 실전 알고리즘 강좌

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
반응형