【题目描述】
设有由n(1≤n≤200)个不相同的整数组成的数列,记为:b(1)、b(2)、……、b(n)若存在i1<i2<i3<…<ie 且有b(i1)<=b(i2)<=…<=b(ie)则称为长度为e的不下降序列。程序要求,当原数列出之后,求出最长的不下降序列。
例如13,7,9,16,38,24,37,18,44,19,21,22,63,15。例中13,16,18,19,21,22,63就是一个长度为7的不下降序列,同时也有7 ,9,16,18,19,21,22,63组成的长度为8的不下降序列。
【输入】
第一行为n,第二行为用空格隔开的n个整数。
【输出】
第一行为输出最大个数max;
第二行为max个整数形成的不下降序列,答案可能不唯一,输出一种就可以了,本题进行特殊评测。
#include<iostream>
#include<cstdio>
#include<vector>
#include<algorithm>
using namespace std;
const int N=210;
int a[N],f[N],g[N];
int main(){
int n;
cin>>n;
for(int i=1;i<=n;i++){
scanf("%d",&a[i]);
f[i]=1;//初始化
}
for(int i=2;i<=n;i++)//从i=2开始
for(int j=1;j<i;j++)
if(a[i]>=a[j]){
if(f[i]<f[j]+1){
f[i]=f[j]+1;
g[i]=j;//f[i]由g[i]转移而来
}
}
//找到最大f[k]的k
int k=0,res=0;
for(int i=1;i<=n;i++){
if(f[i]>res){
res=f[i];
k=i;
}
}
cout<<"max="<<f[k]<<endl;
//f[k]:以a[k]结尾的最大不降子序列长度
vector<int> ans;//存储方案
for(int i=1,len=f[k];i<=len;i++){
ans.push_back(a[k]);
k=g[k];
}
//反向输出
for(int i=ans.size()-1;i>=0;i--){
cout<<ans[i]<<' ';
}
return 0;
}