Algorithm/Algorithm 문제
백준_11003 최솟값 찾기 (슬라이딩 윈도우)
kjyyjk
2023. 11. 29. 23:18
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Deque;
import java.util.LinkedList;
import java.util.StringTokenizer;
public class BJ_11003 {
static class Node {
long ind;
long val;
Node(long ind, long val) {
this.ind = ind;
this.val = val;
}
}
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringBuilder sb = new StringBuilder();
StringTokenizer st = new StringTokenizer(br.readLine(), " ");
int i;
int n = Integer.parseInt(st.nextToken());
int l = Integer.parseInt(st.nextToken());
st = new StringTokenizer(br.readLine(), " ");
Deque<Node> deque = new LinkedList<>();
for(i=0; i<n; i++) {
long temp = Long.parseLong(st.nextToken());
while(!deque.isEmpty() && deque.getLast().val > temp) {
deque.removeLast();
}
deque.add(new Node(i, temp));
if(deque.getFirst().ind <= i - l) {
deque.removeFirst();
}
sb.append(deque.getFirst().val).append(" ");
}
System.out.println(sb);
br.close();
}
}
11003번: 최솟값 찾기
N개의 수 A1, A2, ..., AN과 L이 주어진다. Di = Ai-L+1 ~ Ai 중의 최솟값이라고 할 때, D에 저장된 수를 출력하는 프로그램을 작성하시오. 이때, i ≤ 0 인 Ai는 무시하고 D를 구해야 한다.
www.acmicpc.net