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] == 6) break; 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 |
'Problem > Brute force' 카테고리의 다른 글
[C/C++] BOJ 1018 :: 체스판 다시 칠하기 (0) | 2019.01.21 |
---|---|
[C/C++] BOJ 15684 :: 사다리 조작 (0) | 2019.01.20 |
[백준알고리즘] 2309번 일곱난쟁이 (0) | 2018.11.26 |
[백준알고리즘] 14502번 연구소 (0) | 2018.11.25 |
[백준알고리즘] 14889번 스타트와 링크 (0) | 2018.11.13 |