반응형
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
- 처우산정
- 6987
- @P0
- 소프티어
- 성적평가
- 경력
- incr
- BFS
- 이분탐색
- boj #19237 #어른 상어
- 백트래킹
- msSQL
- 퇴사통보
- 기술면접
- 처우협의
- 13908
- dfs
- Docker
- 백준
- 오퍼레터
- 파라메트릭
- compose
- softeer
- upper_bound
- OFFSET
- BOJ
- 물채우기
- 매개변수탐색
- Kafka
- 연결요소
Archives
- Today
- Total
기술 블로그
17822번 원판 돌리기 본문
728x90
반응형
https://www.acmicpc.net/problem/17822
bfs로 풀었다.
퍼져나가는 방향을 생각해보니
상하좌우로 퍼져나가므로 bfs를 떠올렸다.
그리고, 첫 행과 마지막 행은 같아야 한다.
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 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 | #include <bits/stdc++.h> using namespace std; #define Max 52 int N, M, T, x, d, k; int dy[4] = { 0, 1, 0, -1 }; int dx[4] = { 1, 0, -1, 0 }; bool visit[Max][Max], isDelete; vector<vector<int> > circle; vector<pair<int, int> > bv; void Update() { k %= M; for (int j = 0; j < N; j++) if ((j + 1) % x == 0) { vector<int> temp; for (int i = 0; i < M; i++) temp.push_back(circle[i][j]); for (int t = 0; t < k; t++) if (d == 0) // 시계 { temp.insert(temp.begin(), temp.back()); temp.pop_back(); } else if (d == 1) // 반시계 { temp.push_back(temp.front()); temp.erase(temp.begin()); } for (int i = 0; i < M; i++) if (i == 0) circle[i][j] = circle[M][j] = temp[i]; else circle[i][j] = temp[i]; } } void bfs(queue<pair<int, int> > q, int now) { while (!q.empty()) { int qs = q.size(); while (qs--) { 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 > M || x < 0 || x >= N || circle[y][x] != now || visit[y][x]) continue; visit[y][x] = true; q.push({ y, x }); bv.push_back({ y, x }); } } } if (bv.size() >= 2) for (auto i : bv) { isDelete = true; if (i.first == 0) circle[M][i.second] = 0; circle[i.first][i.second] = 0; } } void Delete() { isDelete = false; for (int i = 0; i < M; i++) for (int j = 0; j < N; j++) { if (circle[i][j] == 0) continue; queue<pair<int, int> > q; memset(visit, false, sizeof(visit)); bv.clear(); int now = circle[i][j]; q.push({ i, j }); visit[i][j] = true; bv.push_back({ i, j }); if (i == 0) { q.push({ M, j }); visit[M][j] = true; } bfs(q, now); } if (!isDelete) { double sum = 0.0, cnt = 0.0; for (int i = 0; i < M; i++) for (int j = 0; j < N; j++) { if (circle[i][j] == 0) continue; sum += (double)circle[i][j]; ++cnt; } double avg = sum / cnt; for (int i = 0; i < M; i++) for (int j = 0; j < N; j++) { if (circle[i][j] == 0) continue; if ((double)circle[i][j] < avg) ++circle[i][j]; else if((double)circle[i][j] > avg) --circle[i][j]; // 이 부분 깜빡 if (i == 0) circle[M][j] = circle[i][j]; } } } int answer() { int ret = 0; for (int i = 0; i < M; i++) for (int j = 0; j < N; j++) ret += circle[i][j]; return ret; } int main(void) { //freopen("C:\\Users\\park7\\Desktop\\sample_input.txt", "r", stdin); vector<int> v[Max]; int input; scanf("%d %d %d", &N, &M, &T); for (int i = 1; i <= N; i++) for (int j = 0; j < M; j++) { scanf("%d", &input); v[i].push_back(input); } vector<int> f; for (int j = 0; j < M; j++) { vector<int> temp; for (int i = 1; i <= N; i++) temp.push_back(v[i][j]); if (j == 0) f = temp; circle.push_back(temp); } circle.push_back(f); for (int i = 0; i < T; i++) { scanf("%d %d %d", &x, &d, &k); Update(); Delete(); } printf("%d\n", answer()); return 0; } | cs |
728x90
반응형
'알고리즘 문제 > BOJ' 카테고리의 다른 글
2931번 가스관 (0) | 2019.11.16 |
---|---|
17780번 새로운 게임 (0) | 2019.11.13 |
7453번 합이 0인 네 정수 (0) | 2019.10.30 |
17779번 게리맨더링 2 (0) | 2019.10.23 |
5397번 키로거 (0) | 2019.10.21 |