设为首页 加入收藏

TOP

最长公共上升子序列(LCIS)ZOJ 2432
2015-07-20 18:05:36 来源: 作者: 【 】 浏览:3
Tags:最长 公共 上升 序列 LCIS ZOJ 2432

立方算法:

#include
  
   
#include
   
     #include
    
      #include
     
       #define M 505 using namespace std; typedef long long LL; LL a[M],b[M]; int dp[M][M]; int main() { //freopen("in.txt","r",stdin); int T; cin>>T; while(T--) { int n1,n2; cin>>n1; for(int i=1; i<=n1; i++)cin>>a[i]; cin>>n2; for(int i=1; i<=n2; i++)cin>>b[i]; memset(dp,0,sizeof(dp)); for(int i=1; i<=n1; i++) { for(int j=1; j<=n2; j++) { dp[i][j]=dp[i-1][j]; if(a[i]==b[j])dp[i][j]=1; if(a[i]==b[j])for(int k=1; k
      
       b[k])dp[i][j]=max(dp[i][j],dp[i][k]+1); } } } int ans=0; for(int j=1;j<=n2;j++)if(dp[n1][j]>ans) { ans=dp[n1][j]; } cout<
       
        
平方算法:

#include
         
          
#include
          
            #include
           
             #include
            
              #define M 505 using namespace std; typedef long long LL; LL a[M],b[M]; int dp[M][M]; int main() { //freopen("in.txt","r",stdin); int T; cin>>T; while(T--) { int n1,n2; cin>>n1; for(int i=1; i<=n1; i++)cin>>a[i]; cin>>n2; for(int i=1; i<=n2; i++)cin>>b[i]; memset(dp,0,sizeof(dp)); for(int i=1; i<=n1; i++) { int max_=0; for(int j=1; j<=n2; j++) { dp[i][j]=dp[i-1][j]; if(a[i]>b[j]&&dp[i][j]>max_)max_=dp[i][j]; else if(a[i]==b[j])dp[i][j]=max_+1; } } int ans=0; for(int i=1; i<=n2; i++)ans=max(ans,dp[n1][i]); cout<
             
              


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇c++构造函数char型指针要重新申请.. 下一篇poj 3026 Borg Maze (bfs + 最小..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: