반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- 처우산정
- boj #19237 #어른 상어
- 퇴사통보
- msSQL
- upper_bound
- Docker
- 6987
- 기술면접
- 백트래킹
- 매개변수탐색
- 소프티어
- 오퍼레터
- softeer
- BFS
- 백준
- 경력
- 물채우기
- 이분탐색
- 성적평가
- 연결요소
- OFFSET
- 13908
- incr
- compose
- 처우협의
- BOJ
- 파라메트릭
- @P0
- dfs
- Kafka
Archives
- Today
- Total
기술 블로그
17141번 연구소 2 본문
728x90
반응형
https://www.acmicpc.net/problem/17141
전형적인 BFS + 백트래킹 문제이다.
80번 째 줄에 return time;이 아니라 return time - 1;인 이유는
BFS 진행 중에 return을 하는 것이 아니라, while을 모두 빠져난 후에 return하는 것이므로
1을 감소시켜 return 해야한다.
Map[행][열]에 값(value)를 부여시켜, spread() 함수 실행 후
0이 그대로 있으면, 따로 MIN_time을 갱신하지 않고, 그 전에 return 해주면 된다.
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 | #include <iostream> #include <queue> #include <stack> #include <cstdio> #include <vector> #include <cstring> #include <string> #include <math.h> #include <algorithm> #include <map> #include <set> #include <sstream> #include <tuple> #pragma warning(disable:4996) #pragma comment(linker, "/STACK:336777216") using namespace std; #define value 100 int Map[55][55] = { 0, }, arr[55][55] = { 0, }, N = 0, M = 0, MIN_time = 0; int dy[4] = { 0, 1, 0, -1 }; int dx[4] = { 1, 0, -1, 0 }; vector<pair<int, int> > v; bool zero() { for (int i = 0; i < N; i++) for (int j = 0; j < N; j++) if (Map[i][j] == 0) return true; return false; } int spread(vector<pair<int, int> > vc) { int time = 0; bool visit[55][55] = { false, }; queue<pair<int, int> > q; for (int i = 0; i < vc.size(); i++) { Map[vc.at(i).first][vc.at(i).second] = value; visit[vc.at(i).first][vc.at(i).second] = true; q.push({ vc.at(i).first, vc.at(i).second }); } while (!q.empty()) { int qSize = q.size(); while (qSize--) { int r = q.front().first; int c = q.front().second; q.pop(); for (int i = 0; i < 4; i++) { int y = r + dy[i]; int x = c + dx[i]; if (y < 0 || y >= N || x < 0 || x >= N || visit[y][x] || Map[y][x] == 1) continue; Map[y][x] = value; q.push({ y, x }); visit[y][x] = true; } } ++time; } return time - 1; } void update() { for (int i = 0; i < N; i++) for (int j = 0; j < N; j++) Map[i][j] = arr[i][j]; } void simulation(vector<pair<int, int> > vc, int pos) { if (vc.size() == M) { update(); int mt = spread(vc); if (zero()) return; MIN_time = min(MIN_time, mt); return; } for (int i = pos; i < v.size(); i++) { vc.push_back(v.at(i)); simulation(vc, i + 1); vc.pop_back(); } } int main(void) { MIN_time = 1e9; scanf("%d %d", &N, &M); for (int i = 0; i < N; i++) for (int j = 0; j < N; j++) { scanf("%d", &Map[i][j]); arr[i][j] = Map[i][j]; if (Map[i][j] == 2) v.push_back({ i,j }); } vector<pair<int, int> > vc; simulation(vc, 0); if (MIN_time == 1e9) MIN_time = -1; printf("%d\n", MIN_time); return 0; } | cs |
728x90
반응형
'알고리즘 문제 > BOJ' 카테고리의 다른 글
17142번 연구소 3 (0) | 2019.04.16 |
---|---|
17143번 낚시왕 (0) | 2019.04.16 |
2744번 대소문자 바꾸기 (0) | 2019.04.14 |
16938번 캠프 준비 (0) | 2019.04.14 |
16937번 두 스티커 (0) | 2019.04.14 |