본문 바로가기

Problem/Brute force

[C/C++] BOJ 15683 :: 감시

BOJ 15683 :: 감시



문제 링크 : https://www.acmicpc.net/problem/15683







이건 누가 봐도 trash 코드이다.... ㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋ

cctv 번호, 회전해야 하는 횟수, 감시할 수 있는 방향 갯수에 따라 숫자를 대입해서 풀었는데

경우의 수가 너무 많다...ㅋㅋㅋㅋㅋㅋㅋㅋㅋ 가독성도 엄청 떨어짐 ㅠ 나중에 연구해서 코드를 고쳐야겠다..




나의 코드



Github : https://github.com/j2wooooo/Daliy_Algorithms/blob/master/Daliy_Algorithms/BOJ_15683/BOJ_15683.cpp




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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
// 백준알고리즘 15683번 :: 감시
#include<iostream>
#include<queue>
using namespace std;
 
struct CCTV
{
    int x;
    int y;
    int CTNUM;
};
 
int N, M;
int office[9][9];
struct CCTV CCTV[9];
int ans = -1;
int direct[6= { 0,4,2,4,4,1 };
int rot[6= { 0,1,2,2,3,4 };
 
// 상 우 하 좌
int dx[4= { -1,0,1,0 };
int dy[4= { 0,1,0,-1 };
 
int count_office()
{
    int value = 0;
 
    for (int i = 0; i < N; i++)
    {
        for (int j = 0; j < M; j++)
        {
            if (!office[i][j]) value++;
        }
    }
    return value;
}
void monitor(int _idx, int _num)
{
    int cctv_num = CCTV[_idx].CTNUM; // cctv 번호
    int rot_cnt = rot[cctv_num]; // cctv 번호에 따른 회전 횟수
    int mx = 0;
    int my = 0;
    int dir = 0// 방향
 
    for (int i = 0; i < rot_cnt; i++)
    {
        // cctv_num, _num, i
        // _num : 몇 번 돌려야 하는지, i : 몇 방향 감시할 수 있는지
        if (cctv_num == 1 && _num == 0) dir = 1;
        else if (cctv_num == 1 && _num == 1) dir = 2;
        else if (cctv_num == 1 && _num == 2) dir = 3;
        else if (cctv_num == 1 && _num == 3) dir = 0;
        else if (cctv_num == 2 && _num == 0 && i == 0) dir = 1;
        else if (cctv_num == 2 && _num == 0 && i == 1) dir = 3;
        else if (cctv_num == 2 && _num == 1 && i == 0) dir = 0;
        else if (cctv_num == 2 && _num == 1 && i == 1) dir = 2;
        else if (cctv_num == 3 && _num == 0 && i == 0) dir = 0;
        else if (cctv_num == 3 && _num == 0 && i == 1) dir = 1;
        else if (cctv_num == 3 && _num == 1 && i == 0) dir = 1;
        else if (cctv_num == 3 && _num == 1 && i == 1) dir = 2;
        else if (cctv_num == 3 && _num == 2 && i == 0) dir = 2;
        else if (cctv_num == 3 && _num == 2 && i == 1) dir = 3;
        else if (cctv_num == 3 && _num == 3 && i == 0) dir = 3;
        else if (cctv_num == 3 && _num == 3 && i == 1) dir = 0;
        else if (cctv_num == 4 && _num == 0 && i == 0) dir = 3;
        else if (cctv_num == 4 && _num == 0 && i == 1) dir = 0;
        else if (cctv_num == 4 && _num == 0 && i == 2) dir = 1;
        else if (cctv_num == 4 && _num == 1 && i == 0) dir = 0;
        else if (cctv_num == 4 && _num == 1 && i == 1) dir = 1;
        else if (cctv_num == 4 && _num == 1 && i == 2) dir = 2;
        else if (cctv_num == 4 && _num == 2 && i == 0) dir = 1;
        else if (cctv_num == 4 && _num == 2 && i == 1) dir = 2;
        else if (cctv_num == 4 && _num == 2 && i == 2) dir = 3;
        else if (cctv_num == 4 && _num == 3 && i == 0) dir = 2;
        else if (cctv_num == 4 && _num == 3 && i == 1) dir = 3;
        else if (cctv_num == 4 && _num == 3 && i == 2) dir = 0;
        else if (cctv_num == 5 && _num == 0 && i == 0) dir = 0;
        else if (cctv_num == 5 && _num == 0 && i == 1) dir = 1;
        else if (cctv_num == 5 && _num == 0 && i == 2) dir = 2;
        else if (cctv_num == 5 && _num == 0 && i == 3) dir = 3;
 
        mx = CCTV[_idx].x + dx[dir];
        my = CCTV[_idx].y + dy[dir];
 
        while (1)
        {
            if (mx < 0 || mx >= N || my < 0 || my >= M) break;
            if (office[mx][my] == 6break;
            if (office[mx][my] == 0) office[mx][my] = -1;
            mx += dx[dir];
            my += dy[dir];
        }
    }
}
void search(int idx)
{
    if (idx < 0)
    {
        int value = count_office();
        if (ans == -1 || ans > value) {
            ans = value;
        }
        return;
    }
 
    int temp[9][9];
    for (int i = 0; i < N; i++)
        for (int j = 0; j < M; j++)
            temp[i][j] = office[i][j];
 
    // CCTV[idx]번 cctv로 감시할 수 있는 칸을 감시한다.
    // office에 갱신한다.
    int cctv_num = CCTV[idx].CTNUM;
    for (int i = 0; i < direct[cctv_num]; i++)
    {
        monitor(idx, i);
        search(idx - 1);
 
        for (int i = 0; i < N; i++)
            for (int j = 0; j < M; j++)
                office[i][j] = temp[i][j];
    }
}
int main(void)
 
{
    cin >> N >> M;
 
    int idx = 0;
 
    for (int i = 0; i < N; i++)
    {
        for (int j = 0; j < M; j++)
        {
            cin >> office[i][j];
            if (office[i][j] >= 1 && office[i][j] <= 5)
            {
                CCTV[idx].CTNUM = office[i][j];
                CCTV[idx].x = i;
                CCTV[idx].y = j;
                idx++;
            }
        }
    }
 
    search(idx-1);
 
    cout << ans;
}
cs