码迷,mamicode.com
首页 > 其他好文 > 详细

POJ 1692 Crossed Matchings(dp).

时间:2014-08-15 09:31:17      阅读:205      评论:0      收藏:0      [点我收藏+]

标签:poj 1692   crossed matchings   there are two rows o   dp   

~~~~

题意:给出两行数字序列,求上下匹配的最多组数是多少.
匹配规则:
1.匹配对的数字必须相同。
2.每个匹配必须有且只能有一个匹配与之相交叉,且相交叉的两组匹配数字必须不同。
3.一个数最多只能匹配一次。

最长公共子序列的改编,令f[i][j]表示第一个序列的前i个数字和第二个序列的前j个数字的匹配的最优值。

状态转移:f[i][j]=max(f[p-1][q-1]+2,max(f[i-1][j],f[i][j-1]))

&&(a[p]==b[j],b[q]==a[i]);

*以f[p-1][q-1]更新f[i][j]就能保证一个数最多只能匹配一次。

题目链接:http://poj.org/problem?id=1692

~~~~

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<cmath>
#define N 1000
using namespace std;

int f[N][N];
int a[N],b[N];
int main()
{
    int t;
    scanf("%d",&t);
    while(t--)
    {
        int n,m;
        scanf("%d%d",&n,&m);
        int i,j,p,q;
        for(i=1;i<=n;i++)
            scanf("%d",&a[i]);
        for(j=1;j<=m;j++)
            scanf("%d",&b[j]);
        memset(f,0,sizeof(f));
        for(i=1;i<=n;i++)
        {
            for(j=1;j<=m;j++)
            {
                for(q=j-1;q>0;q--)
                    if(b[q]==a[i]) break;
                for(p=i-1;p>0;p--)
                    if(a[p]==b[j]) break;
                if(p>0 && q>0 && a[i]!=b[j])   //~~~
                    f[i][j]=max(f[p-1][q-1]+2,max(f[i][j-1],f[i-1][j]));
                else
                    f[i][j]=max(f[i][j-1],f[i-1][j]);
            }
        }
        printf("%d\n",f[n][m]);
    }
    return 0;
}


POJ 1692 Crossed Matchings(dp).,布布扣,bubuko.com

POJ 1692 Crossed Matchings(dp).

标签:poj 1692   crossed matchings   there are two rows o   dp   

原文地址:http://blog.csdn.net/darwin_/article/details/38579967

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!