[BaekJoon] 1818 책정리 (Java)

오태호·2023년 6월 16일
0

백준 알고리즘

목록 보기
251/396
post-thumbnail

1.  문제 링크

https://www.acmicpc.net/problem/1818

2.  문제


3.  소스코드

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.List;
import java.util.StringTokenizer;

public class Main {
    static int N;
    static int[] books;

    static void input() {
        Reader scanner = new Reader();

        N = scanner.nextInt();
        books = new int[N];

        for(int idx = 0; idx < N; idx++) books[idx] = scanner.nextInt();
    }

    static void solution() {
        /*
        한 책을 꺼내서 다른 위치 어디든 꽂을 수 있기 때문에
        가장 긴 증가하는 수열을 구하고 그 수열에 포함되어 있는 책들은 그대로 둔다
        그 수열에 포함되어 있지 않는 책들을 자신의 자리에 꽂으면 최소 횟수로 책을 옮길 수 있다
         */
        List<Integer> LIS = new ArrayList<>();
        LIS.add(0);

        for(int idx = 0; idx < N; idx++) {
            int book = books[idx];

            if(LIS.get(LIS.size() - 1) < book) {
                LIS.add(book);
            } else {
                int index = binarySearch(1, LIS.size() - 1, book, LIS);
                LIS.set(index, book);
            }
        }

        int size = LIS.size() - 1 == 0 ? 1 : LIS.size() - 1;
        System.out.println(N - size);
    }

    static int binarySearch(int min, int max, int book, List<Integer> LIS) {
        while(min < max) {
            int mid = (min + max) / 2;

            if(LIS.get(mid) < book) min = mid + 1;
            else max = mid;
        }

        return max;
    }

    public static void main(String[] args) {
        input();
        solution();
    }

    static class Reader {
        BufferedReader br;
        StringTokenizer st;

        public Reader() {
            br = new BufferedReader(new InputStreamReader(System.in));
        }

        String next() {
            while(st == null || !st.hasMoreElements()) {
                try {
                    st = new StringTokenizer(br.readLine());
                } catch (IOException e) {
                    e.printStackTrace();
                }
            }

            return st.nextToken();
        }

        int nextInt() {
            return Integer.parseInt(next());
        }
    }
}
profile
자바, 웹 개발을 열심히 공부하고 있습니다!

0개의 댓글