가장 긴 감소하는 부분 수열
티어 : Silver 2
시간 제한 : 1 초
메모리 제한 : 256 MB
알고리즘 분류 : 다이나믹 프로그래밍
문제
수열 A가 주어졌을 때, 가장 긴 감소하는 부분 수열을 구하는 프로그램을 작성하시오.
예를 들어, 수열 A = {10, 30, 10, 20, 20, 10} 인 경우에 가장 긴 감소하는 부분 수열은 A = {10, 30, 10, 20, 20, 10} 이고, 길이는 3이다.
입력
첫째 줄에 수열 A의 크기 N (1 ≤ N ≤ 1,000)이 주어진다.
둘째 줄에는 수열 A를 이루고 있는 Ai가 주어진다. (1 ≤ Ai ≤ 1,000)
출력
첫째 줄에 수열 A의 가장 긴 감소하는 부분 수열의 길이를 출력한다.
예제 입출력
Algorithm
가장 긴 감소하는 부분 수열은 가장 긴 증가하는 부분 수열을 이용
dp[i] : i번째 원소를 마지막으로 하는 부분 증가수열의 길이
1. 입력 받는 수열을 reverse
2. 가장 긴 증가하는 부분 수열 찾기
Code
N = int(input())
A = list(map(int, input().split()))
# 수열 reverse
A.reverse()
dp = [1] * N
for i in range(1, N):
for j in range(i):
if A[j] < A[i]:
dp[i] = max(dp[i], dp[j] + 1)
print(max(dp))
메모리: 30864 KB
시간: 196 ms
'백준' 카테고리의 다른 글
[백준 1446] 지름길 Python (0) | 2022.03.20 |
---|---|
[백준 4375] 1 Python (0) | 2022.03.19 |
[백준 11053] 가장 긴 증가하는 부분 수열 Python (0) | 2022.03.19 |
[백준 9095] 1, 2, 3 더하기 Python (0) | 2022.03.19 |
[백준 9012] 괄호 Python (0) | 2022.03.19 |