HDU 3722 Card Game(KM算法)

原创 2017年01月03日 15:08:03
一开始数组开小了,T了很久,后来发现自回路的时候忘记加continue,又WA了很久,这水题浪费这么多时间= =。
#include<iostream>
#include<cstring>
using namespace std;
const int maxn=200+5;
int w[maxn][maxn],n,m;
int lx[maxn],ly[maxn];
int Left[maxn];
bool s[maxn],t[maxn];
char ss[maxn][1005];
bool match(int i)
{
    s[i]=true;
    for(int j=1;j<=n;j++) if(lx[i]+ly[j]==w[i][j]&&!t[j]){
        t[j]=true;
        if(!Left[j]||match(Left[j])){
            Left[j]=i;
            return true;
        }
    }
    return false;
}
void update()
{
    int a=(1<<30);
    for(int i=1;i<=n;i++) if(s[i])
        for(int j=1;j<=n;j++) if(!t[j])
            a=min(a,lx[i]+ly[j]-w[i][j]);
    for(int i=1;i<=n;i++){
        if(s[i]) lx[i]-=a;
        if(t[i]) ly[i]+=a;
    }
}
void KM()
{
    for(int i=1;i<=n;i++){
        Left[i]=lx[i]=ly[i]=0;
        for(int j=1;j<=n;j++)
            lx[i]=max(lx[i],w[i][j]);
    }
    for(int i=1;i<=n;i++){
        for(;;)
        {
            for(int j=1;j<=n;j++) s[j]=t[j]=0;
            if(match(i)) break;else update();
        }
    }
}
int main()
{
    while(~scanf("%d",&n))
    {
        for(int i=1;i<=n;i++) scanf("%s",ss[i]);
        if(n==1) {printf("0\n");continue;}
        for(int i=1;i<=n;i++){
            for(int j=1;j<=n;j++){
                if(i==j) {w[i][j]=0;continue;}
                int len=0;
                for(int k1=0,k2=(int)strlen(ss[j])-1;k1<(int)strlen(ss[i])&&k2>=0;k1++,k2--)
                {
                    if(ss[i][k1]==ss[j][k2]) len++;
                    else break;
                }
                w[i][j]=len;
            }
        }
        KM();
        int ans=0;
        for(int i=1;i<=n;i++) ans+=w[Left[i]][i];
        printf("%d\n",ans);
    }
    return 0;
}

HDU 3722 Card Game KM水题

题目:http://acm.hdu.edu.cn/showproblem.php?pid=3722 大意就是给n个字符串,然后对于任意两个字符串进行匹配,第一个倒序,第二个正序,找它们的最长公共前缀...
  • discreeter
  • discreeter
  • 2015年12月08日 21:10
  • 393

hdu 3722 Card Game (km)

感觉题中这句“Jimmy wants to stick them into several circles, and each card belongs to one circle exactly.”...
  • diary_yang
  • diary_yang
  • 2013年10月10日 13:00
  • 927

hdu 3722 Card Game (KM )

Card Game Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...
  • u010228612
  • u010228612
  • 2013年10月12日 12:32
  • 919

hdu 3722 Card Game【KM】

Card Game Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) To...
  • mengxiang000000
  • mengxiang000000
  • 2016年09月20日 15:04
  • 447

hdu 3722 Card Game(KM算法)

Card Game Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Tota...
  • acm_BaiHuzi
  • acm_BaiHuzi
  • 2015年09月11日 16:41
  • 340

HDU 3722 Card Game(KM最大匹配)

HDU 3722 Card Game 题目链接 题意:给定一些字符串,每次可以选两个a,b出来,a的前缀和b的后缀的最长公共长度就是获得的值,字符串不能重复选,问最大能获得多少值 思...
  • u011217342
  • u011217342
  • 2014年10月31日 19:21
  • 672

HDU 3722 Card Game

题目链接:HDU3722 Card Game Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Ja...
  • u010536683
  • u010536683
  • 2013年10月08日 21:24
  • 400

HDU 3722 Card Game(二分图最优匹配)

HDU 3722 Card Game(二分图最优匹配) http://acm.hdu.edu.cn/showproblem.php?pid=3722 题意:        给出n个字符串,其中任意两个...
  • u013480600
  • u013480600
  • 2014年08月22日 21:43
  • 763

HDU 3722 KM模板题

/***************************************************************************************************...
  • codeforces_sphinx
  • codeforces_sphinx
  • 2011年10月10日 16:47
  • 585

HDU 1067 Gap

Let's play a card game called Gap.  You have 28 cards labeled with two-digit numbers. The first dig...
  • CS33sun
  • CS33sun
  • 2018年01月04日 15:38
  • 62
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:HDU 3722 Card Game(KM算法)
举报原因:
原因补充:

(最多只允许输入30个字)