- 코드
정답 코드 : 기존의 이진탐색, LIS 알고리즘 코드만으로는 풀 수 없어서, index를 배열에 저장해놨다가 출력할 때 index를 활용해서 차례대로 출력이 나오게 풀었다.
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Main {
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
int N = Integer.parseInt(br.readLine());
int[] inputArray = new int[N];
int[] LIS = new int[N];
int[] arrayIndexes = new int[N];
StringTokenizer st = new StringTokenizer(br.readLine());
for (int i = 0; i < N; i++) {
inputArray[i] = Integer.parseInt(st.nextToken());
}
LIS[0] = inputArray[0];
arrayIndexes[0] = 0;
int j = 0;
for (int i = 1; i < N; i++) {
if (LIS[j] < inputArray[i]) {
LIS[++j] = inputArray[i];
arrayIndexes[i] = j;
} else {
int index = binary(LIS, 0, j, inputArray[i]);
LIS[(int) index] = Math.min(LIS[index], inputArray[i]);
arrayIndexes[i] = index;
}
}
System.out.println(j + 1);
String printString = "";
for (int i = N - 1; i >= 0; i--) {
if (arrayIndexes[i] == j) {
printString = inputArray[i] + " " + printString;
j--;
}
}
System.out.print(printString);
}
static int binary(int[] LIS, int startIndex, int endIndex, int key) {
while (startIndex <= endIndex) {
int mid = (int) ((startIndex + endIndex) / 2);
if (LIS[mid] < key) {
startIndex = mid + 1;
} else {
endIndex = mid - 1;
}
}
return startIndex;
}
}
'algorithm' 카테고리의 다른 글
[JAVA] 백준 1806번 : 부분합 (0) | 2020.08.31 |
---|---|
[JAVA] 백준 14003번 : 가장 긴 증가하는 부분 수열 5 (0) | 2020.08.31 |
[JAVA] 백준 13022번 : 늑대와 올바른 단어 (0) | 2020.08.29 |
[JAVA] 백준 12738번 : 가장 긴 증가하는 부분 수열 3 (0) | 2020.08.28 |
[JAVA] 백준 11053번 : 가장 긴 증가하는 부분 수열 (0) | 2020.08.28 |