티스토리 뷰
백준 :: BOJ :: 17837 :: 새로운 게임 2
출처 : https://www.acmicpc.net/problem/17837
#include <bits/stdc++.h>
using namespace std;
#define F(p,q,r) for(int p=q; p<r; p++)
struct S { int y, x, d; };
int N, K,a,b,c,t,fl, A[14][14], dir[5][2] = { {},{0,1},{0,-1},{-1,0},{1,0} };
deque<int> B[14][14]; S C[11];
int main() {
cin >> N >> K;
F(i, 0, N + 2) {
F(j, 0, N + 2) {
if (!i || !j || i > N || j > N) A[i][j] = 2;
else cin >> A[i][j];
}
}
F(i, 0, K) {
cin >> C[i].y >> C[i].x >> C[i].d; B[C[i].y][C[i].x].push_back(i);
}
while (t++ < 1000) {
F(i, 0, K) {
a = C[i].y, b = C[i].x, c = C[i].d;
a += dir[c][0]; b += dir[c][1]; int si = C[i].y, sj = C[i].x;
if (A[a][b] > 1) {
c += 1; if (c == 3)c = 1; if (c == 5)c = 3; C[i].d = c;
a += dir[c][0]; b += dir[c][1];
if(A[a+dir[c][0]][b+dir[c][1]]<2) a += dir[c][0], b += dir[c][1];
}
int f, D=0,l=B[si][sj].size(), s=0;
if (A[a][b] == 1) {
for (int j = l - 1; j >= 0; j--) {
s = B[si][sj][j]; C[s].y = a; C[s].x = b;
B[a][b].push_back(s); B[si][sj].pop_back();
if (s == i)break;
}
}
else {
F(j, 0, l) {
f = B[si][sj][j]; if (f == i) s = 1;
if (s == 1) {
C[f].y = a; C[f].x = b; B[a][b].push_back(f); D++;
}
}
while (D-- > 0) B[si][sj].pop_back();
}
if (B[a][b].size() >= 4) { fl = 1; break; }
}
if (fl)break;
}
cout << ((t > 1000)?-1:t);
return 0;
}
'알고리즘 > BOJ' 카테고리의 다른 글
[BOJ 17779] 게리맨더링 2 (0) | 2019.10.24 |
---|---|
[BOJ 17142] 연구소 3 (0) | 2019.09.18 |
[BOJ 17140] 이차원 배열과 연산 (0) | 2019.09.18 |
[BOJ 17143] 낚시왕 (0) | 2019.05.14 |
[BOJ 17144] 미세먼지 안녕! (2) | 2019.05.14 |
댓글
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- 17144
- 2018 카카오 블라인드 채용
- 새로운 게임 2
- 17143
- STL
- 시간 복잡도
- SW Expert Academy
- SWEA
- hackerrank
- 17140
- DP
- 17837
- 연구소 3
- 17142
- 트렌드
- 게리맨더링 2
- scanf
- 17779
- 이차원 배열과 연산
- 역량 테스트
- 삼성
- 팁
- string
- 2018 KAKAO BLIND RECRUITMENT
- 알고리즘
- 백준
- boj
- 미세먼지 안녕!
- 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 |
글 보관함