몽상실현개발주의

[BOJ] 11722 / 가장 긴 감소하는 부분 수열 / Python 본문

Algorithm PS/BOJ

[BOJ] 11722 / 가장 긴 감소하는 부분 수열 / Python

migrationArc 2021. 5. 13. 14:13

[BOJ] 11722 / 가장 긴 감소하는 부분 수열 / Python

[BOJ] 11722 / 가장 긴 감소하는 부분 수열 / Python

www.acmicpc.net/problem/11722

 

11722번: 가장 긴 감소하는 부분 수열

수열 A가 주어졌을 때, 가장 긴 감소하는 부분 수열을 구하는 프로그램을 작성하시오. 예를 들어, 수열 A = {10, 30, 10, 20, 20, 10} 인 경우에 가장 긴 감소하는 부분 수열은 A = {10, 30, 10, 20, 20, 10} 

www.acmicpc.net

 

풀이

[BOJ] 11053 / 가장 긴 증가하는 부분 수열 문제의 연관 문제이다.

 

조건만 반대로 작성해 주면 된다.

 

N = int(input())

nums = list(map(int, input().split()))
dp = [1] * N

for i in range(N):
    for j in range(i):
        if nums[i]< nums[j]:
            dp[i] = max(dp[i], dp[j]+1)
            
print(max(dp))

 

Comments