码迷,mamicode.com
首页 > 其他好文 > 详细

POJ-2533.Longest Ordered Subsequence (LIS模版题)

时间:2019-04-03 14:06:06      阅读:152      评论:0      收藏:0      [点我收藏+]

标签:end   style   ring   opened   str   状态转移方程   enc   view   close   

  本题大意:和LIS一样

  本题思路:用dp[ i ]保存前 i 个数中的最长递增序列的长度,则可以得出状态转移方程dp[ i ] = max(dp[ j ] + 1)(j < i)

  参考代码:

技术图片
 1 #include <iostream>
 2 #include <cstring>
 3 #include <algorithm>
 4 using namespace std;
 5 
 6 const int maxn = 1e3 + 5;
 7 int a[maxn], dp[maxn];
 8 
 9 int main () {
10     int n, ans = 0;
11     cin >> n;
12     for(int i = 1; i <= n; i ++)
13         cin >> a[i];
14     for(int i = 1; i <= n; i ++) {
15         dp[i] = 1;
16         for(int j = 1; j < i; j ++) {
17             if(a[i] > a[j]) dp[i] = max(dp[i], dp[j] + 1);
18         }
19         ans = dp[i] > ans ? dp[i] : ans;
20     }
21     cout << ans << endl;
22     return 0;
23 }
View Code

 

POJ-2533.Longest Ordered Subsequence (LIS模版题)

标签:end   style   ring   opened   str   状态转移方程   enc   view   close   

原文地址:https://www.cnblogs.com/bianjunting/p/10648329.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!