Given a sequence with many elements and find the ordered subseqence from the original sequence.
dp[i] means the longest length starting from begin of sequence to element i.
dp[i]=max{dp[j]+1,dp[i]} for 0<=j<i and a[i]<a[j]
pku 2533
the original problem only need find the longest length but the elements in the subsequence cannot be acquried.
in my solution, i add a array to record the previous element index of the current element in the subsequence. after find the longest length of the subsequence we can use the array to find all the element index in the subsequence so that we can get all the elements in the subsequence.
#include <stdio.h> #include <stdlib.h> #include <string.h> #include <vector> using namespace std; int subMax(int * a,int n) { int max = a[0]; int maxindex = 0; for(int i = 1; i< n;i++) { if(a[i]>max){max=a[i];maxindex = i;} } return maxindex; } void findPair(int *a,int n) { int * dp = new int[n]; int * st = new int[n]; memset(dp,0,sizeof(int)*n); memset(st,-1,sizeof(int)*n); for(int i = 0 ; i < n;i++){ for(int j = 0; j < i;j++){ if(a[i]<a[j] && dp[j]+1>dp[i]){ dp[i]=dp[j]+1; st[i]=j; } } } int left = subMax(dp,n); vector<int>sub; while(left!=-1){ sub.push_back(a[left]); left=st[left]; } for(vector<int>::reverse_iterator it = sub.rbegin();it!=sub.rend();it++){ printf("%d,",*it); } delete [] dp; delete [] st; printf("/n"); } int main() { int n; scanf("%d",&n); int * a = new int[n]; for(int i= 0 ;i < n;i++){ scanf("%d",&a[i]); } findPair(a,n); delete [] a; return 0; }