uva 111 History Grading

求两个数列最长公共子序列。
注意输入的不是要求的序列,是需要转换的。
输的是第i件事件发生的编号。
输入方式需要注意。

相关资料
这里写图片描述

#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;

int n,dp[21][21],c[21],t[21];

bool in()
{
    int i,m;
    for(i=1;i<=n;i++)
    {
        if(scanf("%d",&m)!=1) return 0;
        t[m]=i;
    }
    return 1;
}

void out()
{
    memset(dp,0,sizeof(dp));
    int i,j;
    for(i=1;i<=n;i++)
        for(j=1;j<=n;j++)
    {
        dp[i][j]=max(dp[i-1][j],dp[i][j-1]);
        if(c[i]==t[j]) dp[i][j]=max(dp[i][j],dp[i-1][j-1]+1);
    }
    printf("%d
",dp[n][n]);
}
int main()
{
    int i,m;
    scanf("%d",&n);
    for(i=1;i<=n;i++)
    {
        scanf("%d",&m);
        c[m]=i;
    }
    while(in())
        out();
    return 0;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。http://xiang578.top/

原文地址:https://www.cnblogs.com/xryz/p/4848087.html