• 문제 링크
2346번: 풍선 터뜨리기
1번부터 N번까지 N개의 풍선이 원형으로 놓여 있고. i번 풍선의 오른쪽에는 i+1번 풍선이 있고, 왼쪽에는 i-1번 풍선이 있다. 단, 1번 풍선의 왼쪽에 N번 풍선이 있고, N번 풍선의 오른쪽에 1번 풍선
www.acmicpc.net
• 풀이 과정
• 풀이 코드
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.ArrayDeque;
import java.util.Deque;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));
StringTokenizer st;
int n = Integer.parseInt(br.readLine());
Deque<Pair> dq = new ArrayDeque<>();
st = new StringTokenizer(br.readLine());
for (int i = 1; i <= n; i++)
dq.offer(new Pair(i, Integer.parseInt(st.nextToken())));
while (dq.size() > 1) {
Pair cur = dq.poll();
bw.write(cur.num + " ");
int move = cur.move;
if (move > 0) {
for (int i = 0; i < move - 1; i++)
dq.offerLast(dq.pollFirst());
} else {
for (int i = 0; i < -move; i++)
dq.offerFirst(dq.pollLast());
}
}
bw.write(String.valueOf(dq.poll().num));
bw.flush();
}
private static class Pair {
int num, move;
public Pair(int num, int move) {
this.num = num;
this.move = move;
}
}
}
'Problem Solving > Baekjoon' 카테고리의 다른 글
[백준] 13417 카드 문자열 - Data Structure / Java (0) | 2022.12.14 |
---|---|
[백준] 5397 키로거 - Data Structure / Java (0) | 2022.12.13 |
[백준] 20301 반전 요세푸스 - Data Structure / Java (0) | 2022.12.11 |
[백준] 3184 양 - Graph Theory / Java (0) | 2022.12.10 |
[백준] 6118 숨바꼭질 - Graph Theory / Java (0) | 2022.12.09 |
댓글