250x250
Notice
Recent Posts
Recent Comments
Link
반응형
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 29 | 30 | 31 |
Tags
- dfs
- CSS
- 스프링부트
- math
- GC로그수집
- scanner
- string
- BFS
- spring boot
- html
- 힙덤프
- List
- deque
- map
- Union-find
- date
- sql
- JPA
- Calendar
- Java
- alter
- priority_queue
- 큐
- Properties
- union_find
- NIO
- 스택
- 리소스모니터링
- set
- javascript
Archives
- Today
- Total
매일 조금씩
이코테 DP : 병사 배치하기 [C++] 본문
728x90
반응형
이문제는 가장 긴 증가하는 부분수열(LIS)을 푸는 방식과 매우 비슷하다.
다만 여기선 가장 긴 감소하는 부분 수열을 찾는 문제이며 최댓값을 찾아내는 것이고 순서는 상관없기 때문에
입력받은 값을 reverse시켜서 가장 긴 증가하는 부분 수열처럼 처리하면 된다.
#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
using namespace std;
int n;
vector<int> v;
int main(void) {
cin >> n;
for (int i = 0; i < n; i++) {
int x;
cin >> x;
v.push_back(x);
}
// 순서를 뒤집어 '최장 증가 부분 수열' 문제로 변환
reverse(v.begin(), v.end());
// 다이나믹 프로그래밍을 위한 1차원 DP 테이블 초기화
int dp[2000];
for (int i = 0; i < n; i++) dp[i] = 1;
// 가장 긴 증가하는 부분 수열(LIS) 알고리즘 수행
for (int i = 0; i < n; i++) {
for (int j = 0; j < i; j++) {
if (v[j] < v[i]) dp[i] = max(dp[i], dp[j] + 1);
}
}
int maxValue = 0;
// dp중 가장 큰 수를 찾아서 병사의 수에서 빼기
for (int i = 0; i < n; i++) {
maxValue = max(maxValue, dp[i]);
}
cout << n - maxValue << '\n';
}
728x90
반응형
'알고리즘 > DP' 카테고리의 다른 글
Leet code (Medium) : 139. Word Break - JAVA (0) | 2024.10.13 |
---|---|
Leet code (Medium) : 322. Coin Change - JAVA (0) | 2024.10.13 |
이코테 DP : 금광 [C++] (0) | 2021.04.28 |
이코테 DP : 효율적인 화폐 구성 [C++] (0) | 2021.04.23 |
이코테 DP : 개미 전사 [C++] (0) | 2021.04.23 |