BAEKJOON 🔗 https://www.acmicpc.net/problem/17298
✔️ 17298번: 오큰수 문제
💻 구현 코드
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Stack;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
Stack<Integer> stack = new Stack<Integer>();
int N = Integer.parseInt(br.readLine());
int[] seq = new int[N];
StringTokenizer st = new StringTokenizer(br.readLine(), " ");
for (int i = 0; i < N; i++) {
seq[i] = Integer.parseInt(st.nextToken());
}
for (int i = 0; i < N; i++) {
while (!stack.isEmpty() && seq[stack.peek()] < seq[i]) {
seq[stack.pop()] = seq[i];
}
stack.push(i);
}
while (!stack.isEmpty()) {
seq[stack.pop()] = -1;
}
StringBuilder sb = new StringBuilder();
for (int i = 0; i < N; i++) {
sb.append(seq[i]).append(' ');
}
System.out.println(sb);
}
}
📌 과정 해석
1.
- 첫번째 원소는 이전 원소가 없기 때문에 index 0을 가리키는 0을 스택에 push한다.
(스택이 비어있기 때문에 while문을 수행하지 않는다.)
stack | 배열의 값 |
---|
[0] | [9, 5, 4, 8] |
2.
- Stack의 최상단 값 : 9
- 현재 인덱스 값 : 5
- 5 < 9 이므로 index1를 스택에 push
stack | 배열의 값 |
---|
[0, 1] | [9, 5, 4, 8] |
3.
- Stack의 최상단 값 : 5
- 현재 인덱스 값 : 4
- 4 < 5 이므로 index2를 스택에 push
stack | 배열의 값 |
---|
[0, 1, 2] | [9, 5, 4, 8] |
4.
- Stack의 최상단 값 : 4
- 현재 인덱스 값 : 8
- 8 > 4 이므로 8보다 큰 수가 나오기 전까지 pop 하면서
배열에서의 그 최상단 값을 현재 인덱스 값으로 치환
stack | 배열의 값 |
---|
[0, 1] | [9, 5, 8, 8] |
[0] | [9, 8, 8, 8] |
5.
- Stack의 최상단 값 : 9
- 현재 인덱스 값 : 8
- 8 < 9 이므로 index3를 스택에 push
stack | 배열의 값 |
---|
[0, 3] | [9, 8, 8, 8] |
6.
- 더이상 탐색할 수열이 없다.
- stack에 남아있는 인덱스의 값들은 더이상 뒤에 큰 수가 없기 때문에 -1값으로 치환
stack | 배열의 값 |
---|
[0] | [9, 8, 8, -1] |
[] | [-1, 8, 8, -1] |
💡 최종 결과
-1 8 8 -1