728x90
유형 : DP(다이나믹 프로그래밍)
배열을 뒤집어서 가장 긴 증가하는 수열을 찾는다
예전에 풀었던 문제 11722 가장 긴 감소하는 부분 수열과 똑같은 dp 문제이다. 다만 이번 문제에서는 제외할 병사의 수를 출력해야 하므로
n - dp의 최댓값 (= 가장 긴 수열의 길이) 를 출력해주어야 한다.
https://www.acmicpc.net/problem/11722
가장 긴 감소하는 부분 수열 문제라고 생각하고 풀면 된다 !
n = int(input())
a = list(map(int, input().split())) # 전투력
a.reverse()
dp = [1] * n
for i in range(1, n):
for j in range(0, i):
if a[i] > a[j]:
dp[i] = max(dp[i], dp[j] + 1)
print(n - max(dp))
728x90
'Algorithm (PS)' 카테고리의 다른 글
[백준] 11054 가장 긴 바이토닉 부분 수열 in python (0) | 2022.01.31 |
---|---|
[백준] 1991 트리 순회 (0) | 2022.01.28 |
[백준] 9663 N-Queen Python 풀이 와 백트래킹, 그리고 DFS의 비효율적인 사용 (0) | 2022.01.27 |
[백준] 11728 배열 합치기 in Python + 반복문 대신 join()으로 출력하기 (0) | 2022.01.26 |
[백준] 11404 플로이드 -> 최단 경로 찾기 알고리즘 (0) | 2022.01.25 |