#include<stdio.h>

#include<string.h>

#include<math.h>

#define inf 0x3fffffff

#define N 300

int map[N][N];

char s[N][N];

int ss[N],tt[N],mark[N],lx[N],ly[N];

struct node{

int x,y;

}man[N],hos[N];

int link[N],n;

int find(int u) {

ss[u]=1;

int i;

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

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

    tt[i]=1;

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

        link[i]=u;

        return 1;

    }

}

return 0;

}

int Max(int a,int b) {

return a>b?a:b;

}

int Min(int a,int b) {

return a>b?b:a;

}

int KM() {

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

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

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

    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(ss,0,sizeof(ss));

        memset(tt,0,sizeof(tt));

        if(find(i))break;

        d=inf;//注意要在这里初始化

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

        if(ss[j]) {

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

                if(!tt[k])

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

        }

       }

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

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

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

       }

     }

    }

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

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

        return -sum;

}

int main() {

    int m,i,j,ma,ho;

    while(scanf("%d%d",&n,&m),n||m) {

        ma=0;ho=0;

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

        scanf("%s",s[i]+1);

        ho=0;ma=0;

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

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

        if(s[i][j]=='m')

            man[++ma].x=i,man[ma].y=j;

            if(s[i][j]=='H')

                hos[++ho].x=i,hos[ho].y=j;

    }

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

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

        map[i][j]=-1*(fabs(1.0*man[i].x-1.0*hos[j].x)+fabs(1.0*man[i].y-1.0*hos[j].y));

        n=ma;

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

        }

return 0;

}

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

  1. HDU SPFA算法 Invitation Cards

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1535 分析: 题意:求1点到其它点的最短距离之和+其它点到1点的最短距离之和 前面一部分直接用SPFA ...

  2. hdu 2255KM算法模板

    #include<stdio.h> #include<string.h> #define N  400 #define inf 0x7fffffff int Max(int a ...

  3. hdu 2435dinic算法模板+最小割性质

    hdu2435最大流最小割 2014-03-22 我来说两句 来源:hdu2435最大流最小割 收藏 我要投稿 2435 There is a war 题意: 给你一个有向图,其中可以有一条边是无敌的 ...

  4. ACM: HDU 1869 六度分离-Dijkstra算法

    HDU 1869六度分离 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Descri ...

  5. ACM: HDU 3790 最短路径问题-Dijkstra算法

    HDU 3790 最短路径问题 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Des ...

  6. ACM: HDU 2544 最短路-Dijkstra算法

    HDU 2544最短路 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Descrip ...

  7. ACM: HDU 1874 畅通工程续-Dijkstra算法

    HDU 1874 畅通工程续 Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u Desc ...

  8. hdu 1385 Minimum Transport Cost (floyd算法)

    貌似···················· 这个算法深的东西还是很不熟悉!继续学习!!!! ++++++++++++++++++++++++++++ ======================== ...

  9. 字符串_KMP算法(求next[]模板 hdu 1711)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1711 问题描述:给两个序列a,b,长度分别为n,m(1<=n<=1000000,1< ...

随机推荐

  1. 洛谷 P1880 [NOI1995]石子合并

    题目描述 在一个圆形操场的四周摆放N堆石子,现要将石子有次序地合并成一堆.规定每次只能选相邻的2堆合并成新的一堆,并将新的一堆的石子数,记为该次合并的得分. 试设计出1个算法,计算出将N堆石子合并成1 ...

  2. laravel ORM 只开启created_at的方法

    class User extends Model { //重写setUpdatedAt方法 public function setUpdatedAt($value) { // Do nothing. ...

  3. 【JS】温故知新: 从parseInt开始

    工作中,几乎习惯了大量使用方便的工具库(如underscore.lodash),但是长期的依赖,却有可能在我们注意不到的地方出现黑天鹅,笔者最近就碰到了这样一件例子: parseInt(9e-10); ...

  4. Hbase源码分析:server端RPC

    server端rpc包括master和RegionServer.接下来主要梳理一下,master和regionserver中有关rpc创建,启动以及处理的过程. 1,server rpc的初始化过程 ...

  5. [译]The multi Interface

    The multi Interfacemulti接口 The easy interface as described in detail in this document is a synchrono ...

  6. 【URL重写】IIS7配置URL重写

    URL Rewrite Module   此模块适用于IIS7.7.5.8. 微软在IIS7中添加了URL的重写模块,并且免费使用,可以导入.htaccess规则,但需要安装. 第一步:安装URL2. ...

  7. 专题十一:实现一个基于FTP协议的程序——文件上传下载器

    引言: 在这个专题将为大家揭开下FTP这个协议的面纱,其实学习知识和生活中的例子都是很相通的,就拿这个专题来说,要了解FTP协议然后根据FTP协议实现一个文件下载器,就和和追MM是差不多的过程的,相信 ...

  8. PLC学习资料

    常用字母 X 输入点(I)可连接外部输入信号 如感应器或限位/按钮等M 内部辅助继电器S 内部步进 不作步进使用时,可用作内部辅助继电器T 时间继电器 内部使用C计数器 内部使用Y输出点(O)输出给外 ...

  9. git Eclipse项目不显示当前分支

    问题: 在Eclipse中,导入新的git项目,在项目上不再显示当前所处的分支,也不再显示修改了哪些文件 解决: 右键选中项目  -->  Team  -->  Share Project ...

  10. NX自动出图 效果图