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