[백준/JAVA] BOJ 11003 - 최솟값 찾기

NAGANG LEE·2024년 1월 30일

알고

목록 보기
67/118

👀 문제

11003번: 최솟값 찾기 ✨ 플래티넘 5

N개의 수 A1, A2, ..., AN과 L이 주어진다.

Di = Ai-L+1 ~ Ai 중의 최솟값이라고 할 때, D에 저장된 수를 출력하는 프로그램을 작성하시오. 이때, i ≤ 0 인 Ai는 무시하고 D를 구해야 한다.

입력 예제

12 3
1 5 2 3 6 2 3 7 3 5 2 6

출력 예제

1 1 1 2 2 2 2 2 3 3 2 2

🔑 키포인트

슬라이딩 윈도우


✍️ 코드

package jan_week5;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.Deque;
import java.util.LinkedList;
import java.util.StringTokenizer;

public class BOJ11003 {
	static class Node {
		int index;
		int value;
		
		public Node(int index, int value) {
			this.index = index;
			this.value = value;
		}
	}
	
	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 = new StringTokenizer(br.readLine());
		
		int n = Integer.parseInt(st.nextToken());
		int l = Integer.parseInt(st.nextToken());
		
		st = new StringTokenizer(br.readLine());
		
		Deque<Node> deque = new LinkedList<>();
		
		for (int i = 0; i < n; i++) {
			int now = Integer.parseInt(st.nextToken());
			
			// 만약 맨 뒤의 노드가 현재 데이터 값보다 크다면 제거 
			// 새로운 값이 들어올 때마다 현재 수보다 큰 값을 덱에서 제거함으로써 시간 복잡도 줄이기 
			while (!deque.isEmpty() && deque.getLast().value > now) {
				deque.removeLast();
			}
			
			// 현재 값 넣어주기 
			deque.addLast(new Node(i, now));
			
			// 인덱스 범위가 슬라이딩 윈도우를 벗어나면 맨 앞에 것 삭제해 주기 
			if (deque.getFirst().index <= i - l) {
				deque.removeFirst();
			}
			
			bw.write(deque.getFirst().value + " ");
		}
		bw.flush();
		bw.close();
	}
}
profile
모바일 개발자를 목표로 하고 있어요 💭

0개의 댓글