간단한 DP 문제
11053번과 거의 같은 문제
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 32 33 34 35 36 | #include <iostream> #include <algorithm> #define MAX 1001 using namespace std; int dp[MAX]; int A[MAX]; int N; void DP(){ int ans=0; for(int i=0;i<N;i++){ dp[i]=1; for(int j=0;j<i;j++){ if(A[i]<A[j]){ dp[i]=max(dp[i],dp[j]+1); } } ans=max(ans,dp[i]); } cout << ans << endl; } int main(){ cin >> N; for(int i=0;i<N;i++){ cin >> A[i]; } DP(); } | cs |
'Coding > 백준' 카테고리의 다른 글
2661번 좋은수열 (0) | 2020.02.20 |
---|---|
11051번 이항 계수 2 (0) | 2020.02.17 |
1759번 암호 만들기 (0) | 2020.02.14 |
2959번 거북이 (0) | 2020.02.13 |
11048번 이동하기 (0) | 2020.02.13 |