Notice
Recent Posts
Recent Comments
Link
«   2025/02   »
1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28
Tags
more
Archives
Today
Total
관리 메뉴

코드와이

[BAEKJOON] 11722. 가장 긴 감소하는 부분 수열 본문

acmicpc

[BAEKJOON] 11722. 가장 긴 감소하는 부분 수열

코드와이 2021. 5. 6. 15:03

 

문제링크

www.acmicpc.net/problem/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);
	}
}