OJ
[BOJ] 12869 뮤탈리스크 (JAVA)
P3PP4
2023. 3. 5. 10:00
https://www.acmicpc.net/problem/12869
12869번: 뮤탈리스크
1, 3, 2 순서대로 공격을 하면, 남은 체력은 (12-9, 10-1, 4-3) = (3, 9, 1)이다. 2, 1, 3 순서대로 공격을 하면, 남은 체력은 (0, 0, 0)이다.
www.acmicpc.net
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.LinkedList;
import java.util.Queue;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int N = Integer.parseInt(br.readLine());
int[] hp = new int[3];
boolean[][][] visited = new boolean[61][61][61];
StringTokenizer st = new StringTokenizer(br.readLine(), " ");
for (int i = 0; i < N; i++) {
hp[i] = Integer.parseInt(st.nextToken());
} // end of input
Queue<int[]> q = new LinkedList<>();
q.offer(new int[] { hp[0], hp[1], hp[2] });
visited[hp[0]][hp[1]][hp[2]] = true;
int time = -1;
while(!q.isEmpty()) {
time++;
int size = q.size();
while(size-- > 0) {
int[] a = q.poll();
if (a[0] == 0 && a[1] == 0 && a[2] == 0) {
System.out.print(time);
return;
}
for (int i = 0; i < 3; i++) {
int n0 = a[0 + i] - 9 < 0 ? 0 : a[0 + i] - 9;
int n1 = a[(1 + i) % 3] - 3 < 0 ? 0 : a[(1 + i) % 3] - 3;
int n2 = a[(2 + i) % 3] - 1 < 0 ? 0 : a[(2 + i) % 3] - 1;
if (!visited[n0][n1][n2]) {
visited[n0][n1][n2] = true;
q.offer(new int[] { n0, n1, n2 });
}
n1 = a[(1 + i) % 3] - 1 < 0 ? 0 : a[(1 + i) % 3] - 1;
n2 = a[(2 + i) % 3] - 3 < 0 ? 0 : a[(2 + i) % 3] - 3;
if (!visited[n0][n1][n2]) {
visited[n0][n1][n2] = true;
q.offer(new int[] { n0, n1, n2 });
}
}
}
}
}
}