NYOJ17 最长单调递增子序列 线性dp
Posted 若有恒,何必三更起五更眠;最无益,莫过一日曝十日寒。
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了NYOJ17 最长单调递增子序列 线性dp相关的知识,希望对你有一定的参考价值。
题目链接:
http://acm.nyist.edu.cn/JudgeOnline/problem.php?pid=17
分析:
i=1
dp[i]=1
i!=1
dp[i]=max(dp[j]+1) j<i&&a[j]<a[i]
代码如下:
#include<bits/stdc++.h> using namespace std; int main() { int n; scanf("%d",&n); getchar(); while(n--) { char a[10005]; gets(a); int l=strlen(a); int dp[l]; dp[0]=1; for(int i=1;i<l;i++) { int t=0; for(int j=0;j<i;j++) { if(a[j]<a[i]) { if(t<dp[j]) { t=dp[j]; } } } dp[i]=t+1; } int t=dp[0]; for(int i=1;i<l;i++) { if(t<dp[i]) { t=dp[i]; } } printf("%d\n",t); } return 0; }
以上是关于NYOJ17 最长单调递增子序列 线性dp的主要内容,如果未能解决你的问题,请参考以下文章