acmicpc
[BAEKJOON] 11722. 가장 긴 감소하는 부분 수열
코드와이
2021. 5. 6. 15:03
문제링크
11722번: 가장 긴 감소하는 부분 수열
수열 A가 주어졌을 때, 가장 긴 감소하는 부분 수열을 구하는 프로그램을 작성하시오. 예를 들어, 수열 A = {10, 30, 10, 20, 20, 10} 인 경우에 가장 긴 감소하는 부분 수열은 A = {10, 30, 10, 20, 20, 10}
www.acmicpc.net
package acmicpc.Silver2;
import java.util.Arrays;
import java.util.Scanner;
public class 가장_긴_감소하는_부분_수열 {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
int n = sc.nextInt();
int[] arr = new int[n];
for(int i = 0 ; i < n ; i++) {
arr[i] = sc.nextInt();
}
int ans = 1;
int[] min = new int[n];
Arrays.fill(min, 1);
for(int i = n-2 ; i >= 0 ; i--) {
for(int j = n-1 ; j > i ; j--) {
if(arr[i] > arr[j]) min[i] = Math.max(min[i], min[j] + 1);
}
ans = Math.max(ans, min[i]);
}
System.out.println(ans);
}
}