문제
12738번: 가장 긴 증가하는 부분 수열 3
첫째 줄에 수열 A의 크기 N (1 ≤ N ≤ 1,000,000)이 주어진다. 둘째 줄에는 수열 A를 이루고 있는 Ai가 주어진다. (-1,000,000,000 ≤ Ai ≤ 1,000,000,000)
www.acmicpc.net
알고리즘
이분 탐색
풀이
가장 긴 증가하는 부분 수열 2 문제에서 입력 값의 범위만 늘어났다.
하지만 늘어난 범위도 int 형 범위 안에 들어가기 때문에 그대로 해결된다.
코드
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.ArrayList;
import java.util.StringTokenizer;
public class Main {
static ArrayList<Integer> list;
public static void main(String[] args) throws NumberFormatException, IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
list = new ArrayList<>();
int N = Integer.parseInt(br.readLine());
StringTokenizer st = new StringTokenizer(br.readLine(), " ");
for (int i = 0; i < N; i++) {
int num = Integer.parseInt(st.nextToken());
if (i == 0 || list.get(list.size() - 1) < num)
list.add(num);
else
list.set(lowerBound(num), num);
}
System.out.println(list.size());
}
static int lowerBound(int num) {
int left = 0;
int right = list.size();
while (left < right) {
int mid = (left + right) / 2;
if (list.get(mid) < num) left = mid + 1;
else right = mid;
}
return right;
}
}
'Algorithm > 백준(BOJ)' 카테고리의 다른 글
[백준] 14003. 가장 긴 증가하는 부분 수열 5 (Java) (0) | 2022.10.07 |
---|---|
[백준] 14002. 가장 긴 증가하는 부분 수열 4 (Java) (1) | 2022.10.07 |
[백준] 12015. 가장 긴 증가하는 부분 수열 2 (Java) (0) | 2022.10.06 |
[백준] 11053. 가장 긴 증가하는 부분 수열 (Java) (0) | 2022.10.06 |
[백준] 20061. 모노미노도미노2 (Java) (0) | 2022.10.06 |