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;
}

hdu3722Card Game KM算法

//n个字符串,对于一个字符串i,j 将i颠倒后与j的公共前缀的大小为i,j的权值 //问将这些字符串拼接起来得到的最大权值 //将这些字符串之间建图,直接求完备匹配的最大权匹配 #include #...
  • cq_pf
  • cq_pf
  • 2015年08月07日 14:53
  • 288

HDU3722 Card Game KM算法的二分图带权匹配

Problem Address:http://acm.hdu.edu.cn/showproblem.php?pid=3722 【前言】 又搜刮来了一份代码。 用于求二分图的带权匹...

hdu 3722 Card Game 求完全图中l个不相交的环的最大权和=最优匹配 KM算法

Problem Description Jimmy invents an interesting card game. There are N cards, each of which contai...

hdu 3722 Card Game(KM算法)

Card Game Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Tota...

HDU3722 Card Game 二分图之最优匹配 KM算法

Problem Description Jimmy invents an interesting card game. There are N cards, each of which contai...

hdu3722Card Game(KM最大带权匹配)

题目请戳这里 题目大意:给n个字符串,再给一个n的排列:p1,p2....pn。然后将第i个字符串贴到第pi个字符串后面,然后形成一个环。pi的首字符和第i个字符串的末尾字符就相邻,如果这2个字符相...

hdu 3722Card Game(KM匹配求环)

//求图中环的最大权 //直接拆点,求二分图的最大权匹配。 #include #include #include using namespace std; #define clr(a) memset(...

HDU 3722 Card Game(KM最大匹配)

这题就是一道KM算法的模版题,下午做比赛的时候两个模版都是TLE,好不科学,比赛结束后去杭电交就成WA了,更不科学……后来发现是建图的时候写挫了T_T,要不比赛的时候就能多出一题了,还有一道匹配题也没...

hdu 3722 Card Game【KM】

Card Game Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) To...

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

HDU 3722 Card Game(二分图最优匹配) http://acm.hdu.edu.cn/showproblem.php?pid=3722 题意:        给出n个字符串,其中任意两个...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:HDU 3722 Card Game(KM算法)
举报原因:
原因补充:

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