diff --git "a/0224LJH/202507/28 BOJ \352\260\200\354\236\245 \352\270\264 \354\246\235\352\260\200\355\225\230\353\212\224 \353\266\200\353\266\204 \354\210\230\354\227\264 4.md" "b/0224LJH/202507/28 BOJ \352\260\200\354\236\245 \352\270\264 \354\246\235\352\260\200\355\225\230\353\212\224 \353\266\200\353\266\204 \354\210\230\354\227\264 4.md" new file mode 100644 index 00000000..d9452e5f --- /dev/null +++ "b/0224LJH/202507/28 BOJ \352\260\200\354\236\245 \352\270\264 \354\246\235\352\260\200\355\225\230\353\212\224 \353\266\200\353\266\204 \354\210\230\354\227\264 4.md" @@ -0,0 +1,76 @@ +```java +import java.io.BufferedReader; +import java.io.IOException; +import java.io.InputStreamReader; +import java.util.Arrays; +import java.util.StringTokenizer; + +public class Main { + + static int size, maxLen; + static int[] arr; + static int[] dp, ans; + + + public static void main(String[] args) throws IOException { + init(); + process(); + print(); + } + + private static void init() throws IOException { + BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); + size = Integer.parseInt(br.readLine()); + arr = new int[size]; + dp = new int[size]; + ans = new int[size]; + maxLen = 1; + StringTokenizer st = new StringTokenizer(br.readLine()); + for (int i = 0; i < size; i++) { + arr[i] = Integer.parseInt(st.nextToken()); + } + } + + private static void process() { + for (int i = 0; i < size; i++) { + dp[i] = 1; + for (int j = 0; j < i; j++) { + if (arr[j] < arr[i]) { + dp[i] = Math.max(dp[i], dp[j] + 1); + } + } + maxLen = Math.max(maxLen, dp[i]); + } + + int lastIndex = -1; + for (int i = size - 1; i >= 0; i--) { + if (dp[i] == maxLen) { + lastIndex = i; + break; + } + } + + // 2. 역추적하면서 수열 구성 + int ansIndex = maxLen - 1; + int currentLen = maxLen; + + for (int i = lastIndex; i >= 0; i--) { + if (dp[i] == currentLen) { + ans[ansIndex--] = arr[i]; + currentLen--; + } + } + } + + private static void print() { + System.out.println(maxLen); + for (int i = 0; i < maxLen; i++) { + System.out.print(ans[i]); + if (i < maxLen - 1) System.out.print(" "); + } + System.out.println(); + } +} + + +``` \ No newline at end of file