코드와이
[BAEKJOON] 11722. 가장 긴 감소하는 부분 수열 본문
문제링크
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);
}
}
'acmicpc' 카테고리의 다른 글
[BAEKJOON] 14503. 로봇 청소기 (0) | 2021.05.09 |
---|---|
[BAEKJOON] 11054. 가장 긴 바이토닉 부분 수열 (0) | 2021.05.06 |
[BAEKJOON] 1655. 가운데를 말해요 (0) | 2021.05.04 |
[BAEKJOON] 12015. 가장 긴 증가하는 부분 수열 2 (0) | 2021.04.29 |
[BAEKJOON] 10942. 팰린드롬? (0) | 2021.04.29 |