#include<stdio.h>

#include<math.h>

#include<string.h>

#define N 200

#define inf 999999999

int Max(int a,int b ) {

    return a>b?a:b;

}

int Min(int a,int b) {

    return a>b?b:a;

}

int map[N][N],lx[N],ly[N],s[N],t[N],link[N],n,m,otm[N];

int find(int u) {

    int i;

    s[u]=1;

    for(i=1;i<=n;i++)  

        if(!t[i]&&lx[u]+ly[i]==map[u][i]) {

            t[i]=1;

            if(link[i]==-1||find(link[i])) {

                link[i]=u;

                return 1;

            }

        }

        return 0;

}

int KM() {

    int i,j,sum=0,d,k,flag;

    memset(ly,0,sizeof(ly));

    memset(link,-1,sizeof(link));

    for(i=1;i<=n;i++) {

        lx[i]=-inf;

        for(j=1;j<=n;j++)

            lx[i]=Max(lx[i],map[i][j]);

    }

        for(i=1;i<=n;i++) {

            while(1) {

                memset(s,0,sizeof(s));

                memset(t,0,sizeof(t));

                if(find(i))break;  

d=inf;//这个必须写到这里否则可能导致死循环我感觉4 4 1 3 3 2 1 2 4 1





for(j=1;j<=n;j++)

if(s[j]) {

                        for(k=1;k<=n;k++)

                            if(!t[k]) 

                                d=Min(d,lx[j]+ly[k]-map[j][k]);

}

                    for(j=1;j<=n;j++) {

                        if(s[j])lx[j]-=d;

                        if(t[j])ly[j]+=d;

                    }

            }

            

        }

        flag=0;

        for(i=1;i<=n;i++) {

            if(link[i]==-1||map[link[i]][i]==-inf) {

                flag=1;

                break;

            }

            sum+=map[link[i]][i];

        }

        if(flag)

            sum=-1;

        else

            sum=-sum;

        return sum;

}

int main() { 

    int i,j,a,b,c;

    while(scanf("%d%d",&n,&m)!=EOF) {

    for(i=1;i<=n;i++)

        for(j=1;j<=n;j++)

            map[i][j]=-inf;

        while(m--) {

            scanf("%d%d%d",&a,&b,&c);

            if(-c>map[a][b])

                map[a][b]=-c;

        }

            printf("%d\n",KM());

    }

    return 0;

}

//another

#include<cstdio>  

#include<cstring>  

#include<algorithm>  

#include<climits>  

#include<iostream>

using namespace std;

#define N 550

#define inf 1<<28

int map[N][N],lx[N],ly[N],s[N],t[N],link[N],n,m,otm[N];

int find(int u) {

int i;

s[u]=1;

for(i=1;i<=n;i++) 

if(!t[i]) {

if(lx[u]+ly[i]==map[u][i]) {

t[i]= 1;

if(link[i]==-1||find(link[i])) {

link[i]=u;

return 1;

}

}

else

otm[i]=min(otm[i],lx[u]+ly[i]-map[u][i]);

}

return 0;

}

void KM() {

int i,j,sum=0,d,k;

memset(ly,0,sizeof(ly));

memset(link,-1,sizeof(link));

for(i=1;i<=n;i++) {

lx[i]=-inf;

for(j=1;j<=n;j++)

lx[i]=max(lx[i],map[i][j]);

}

for(i=1;i<=n;i++) {



while(1) {


for(j=1;j<=n;j++)

otm[j]=inf;

memset(s,0,sizeof(s));

memset(t,0,sizeof(t));

if(find(i))break;

d=inf;//必须加到while循环里面开始这里一直错

for(k=1;k<=n;k++)

if(!t[k]) 

d=min(d,otm[k]);

for(j=1;j<=n;j++) {

if(s[j])lx[j]-=d;

if(t[j])ly[j]+=d;

else

otm[j]-=d;

}

}



}



}

int main() { 

int i,j,a,b,c,flag,sum;

while(scanf("%d%d",&n,&m)!=EOF) {

for(i=1;i<=n;i++)

for(j=1;j<=n;j++)

map[i][j]=-inf;

while(m--) {

scanf("%d%d%d",&a,&b,&c);

if(-c>map[a][b])

map[a][b]=-c;

}

KM();

flag=false;

sum=0;

for(i=1;i<=n;i++) {

if(link[i]==-1||map[link[i]][i]==-inf) {

flag=true;

break;

}

sum+=map[link[i]][i];

}

if(flag)

sum=-1;

else

sum=-sum;

printf("%d\n",sum);

}

return 0;

}

hdu 1853 KM算法的更多相关文章

  1. hdu 3488(KM算法||最小费用最大流)

    Tour Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 65535/65535 K (Java/Others)Total Submis ...

  2. HDU 2255 KM算法 二分图最大权值匹配

    奔小康赚大钱 Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Subm ...

  3. hdu 2448(KM算法+SPFA)

    Mining Station on the Sea Time Limit: 5000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Jav ...

  4. hdu 3395(KM算法||最小费用最大流(第二种超级巧妙))

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

  5. hdu 4862 KM算法 最小K路径覆盖的模型

    http://acm.hdu.edu.cn/showproblem.php?pid=4862 选t<=k次,t条路要经过全部的点一次而且只一次. 建图是问题: 我自己最初就把n*m 个点分别放入 ...

  6. HDU 1533 KM算法(权值最小的最佳匹配)

    Going Home Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total ...

  7. hdu 3435(KM算法最优匹配)

    A new Graph Game Time Limit: 8000/4000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  8. hdu 2255 奔小康赚大钱--KM算法模板

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2255 题意:有N个人跟N个房子,每个人跟房子都有一定的距离,现在要让这N个人全部回到N个房子里面去,要 ...

  9. hdu 2853 Assignment KM算法

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2853 Last year a terrible earthquake attacked Sichuan ...

随机推荐

  1. bzoj 2101: [Usaco2010 Dec]Treasure Chest 藏宝箱【区间dp】

    就是区间dp啦f[i][j]表示以i开头的长为j+1的一段的答案,转移是f[i][j]=s[i+l]-s[i-1]+min(f[i][j-1],f[i+1][j-1]),初始是f[i][1]=a[i] ...

  2. hdu 1043 Eight

    欸我一直以为双向bfs是搜完一半再搜另一半呢,妹想到是两个一起搜 然后队列里放的结构体里不能直接存答案,所以做一个邻接表一样的东西,直接指向需要的字符即可 记录状态用康托展开来hash 以及居然是多组 ...

  3. jwt的应用生成token,redis做储存

    解释一下JWT JWT就是一个字符串,经过加密处理与校验处理的字符串,由三个部分组成.基于token的身份验证可以替代传统的cookie+session身份验证方法.三个部分分别如下: header. ...

  4. less新手入门(四)—— Mixin Guards

    八.Mixin Guards 有条件的 mixin 当您想要匹配表达式时,相对于简单的值或特性,Guards是有用的.如果您熟悉函数式编程,您可能已经遇到过它们. 为了尽可能地保持CSS的声明性质,在 ...

  5. spring cxf 配置步骤

    spring 项目增加web service的步骤:1.复制cxf的jar包2.web.xml配置cxf的核心控制器:org.apache.cxf.transport.servlet.CXFServl ...

  6. {Python}安装第三方包(setup.py)

    在github上下载了records文件到本地. 解压文件 cmd切换到文件setup.py的目录下 先执行 python setup.py build 再执行python setup.py inst ...

  7. css边框样式、边框配色、边框阴影、边框圆角、图片边框

     边框样式 点线式边框 破折线式边框 直线式边框 双线式边框 槽线式边框 脊线式边框 内嵌效果的边框 突起效果的边框 <div style="width: 300px; height: ...

  8. JPEG图像压缩出现资源不足问题的解决

    1,问题的提出 公司开发了一个图像压缩上传程序.采用Delphi语言实现.大致步骤如下: 1,上传前将文件打开装载到TJpegImage, 2,创建一个TBitmap组件,设置其大小,采用Stretc ...

  9. centos如何离线安装部署node&pm2?

    最近我们项目要上即时通讯,因为项目对安全要求比较高,所以选择了即时通讯云服务器yun2win,他们提供了数据服务器让我们自己安装部署.那么问题来了,我们服务器是放在内网,完全无法访问外网,而yun2w ...

  10. swift 工作日志

    开发问题汇总: tableview.register(CEImpWalletHomeCell.self, forCellReuseIdentifier: "cell") var c ...