青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

POJ 2195 Going Home 二分圖完美匹配

Description

On a grid map there are n little men and n houses. In each unit time, every little man can move one unit step, either horizontally, or vertically, to an adjacent point. For each little man, you need to pay a $1 travel fee for every step he moves, until he enters a house. The task is complicated with the restriction that each house can accommodate only one little man.

Your task is to compute the minimum amount of money you need to pay in order to send these n little men into those n different houses. The input is a map of the scenario, a '.' means an empty space, an 'H' represents a house on that point, and am 'm' indicates there is a little man on that point.

You can think of each point on the grid map as a quite large square, so it can hold n little men at the same time; also, it is okay if a little man steps on a grid with a house without entering that house.

Input

There are one or more test cases in the input. Each case starts with a line giving two integers N and M, where N is the number of rows of the map, and M is the number of columns. The rest of the input will be N lines describing the map. You may assume both N and M are between 2 and 100, inclusive. There will be the same number of 'H's and 'm's on the map; and there will be at most 100 houses. Input will terminate with 0 0 for N and M.

Output

For each test case, output one line with the single integer, which is the minimum amount, in dollars, you need to pay.

Sample Input

2 2
.m
H.
5 5
HH..m
.....
.....
.....
mm..H
7 8
...H....
...H....
...H....
mmmHmmmm
...H....
...H....
...H....
0 0

Sample Output

2
10
28

Source


    題目大意:有m個人要進h間房子,從當前位置(x1,y1)進入房子(x2,y2)的時間為|x1-x2|+|y1-y2|,問這m個人都進入房間所需的最小時間是多少。問題可以轉化為帶權二分圖的最小權匹配,以sample 2為例先建立二分圖:
 
(m1,h1)=4,(m1,h2)=3,(m1,h3)=4,(m2,h1)=4,(m2,h2)=5,(m2,h3)=4,(m3,h1)=5,(m3,h2)=4,(m3,h3)=3.
然后用KM算法求解,代碼中的注釋部分為最大權匹配。
#include <iostream>

const int MAX = 101;
const int MAXN = 10001;
const int inf = 0x7FFFFFFF;
struct point{
    
int x,y;
}
man[MAXN],home[MAXN];
bool vx[MAX],vy[MAX];
int m,h,map[MAX][MAXN],lx[MAX],ly[MAX],match[MAX];

bool dfs(int u){
    
int i;
    
for(vx[u]=true,i=0;i<h;i++)
        
if(!vy[i] && lx[u]+ly[i]==map[u][i]){
            vy[i]
=true;
            
if(match[i]==-1 || dfs(match[i])){
                match[i]
=u;
                
return true;
            }

        }

    
return false;
}

int kuhn_munkras(){
    
int i,j,k,min,ans;
    
for(i=0;i<m;i++)
        
for(lx[i]=inf,j=0;j<h;j++)
            
if(map[i][j]<lx[i]) lx[i]=map[i][j];
  
//for(i=0;i<m;i++)
  
//    for(lx[i]=-inf,j=0;j<h;j++)
  
//        if(map[i][j]>lx[i]) lx[i]=map[i][j]; 最大權匹配
    for(i=0;i<h;i++) ly[i]=0;
    memset(match,
-1,sizeof(match));
    
for(i=0;i<m;i++){
        
while(true){
            memset(vx,
false,sizeof(vx));
            memset(vy,
false,sizeof(vy));
            min
=inf;
            
if(dfs(i)) break;
            
for(j=0;j<m;j++){
                
if(vx[j]){
                    
for(k=0;k<h;k++)
                        
if(!vy[k] && map[j][k]-lx[j]-ly[k]<min)
                            min
=map[j][k]-lx[j]-ly[k];
                      
//if(!vy[k] && lx[j]+ly[k]-map[j][k]<min)
                      
//    min=map[j][k]-lx[j]-ly[k]; 最大權匹配
                }

            }

            
for(j=0;j<m;j++if(vx[j]) lx[j]+=min;
            
for(j=0;j<h;j++if(vy[j]) ly[j]-=min;
        }

    }

    
for(ans=i=0;i<h;i++) ans+=map[match[i]][i];
    
return ans;
}

int main(){
    
char ch;
    
int i,j,row,colum;
    
while(scanf("%d %d",&row,&colum),row||colum){
        
for(getchar(),m=h=i=0;i<row;i++){
            
for(j=0;j<colum;j++){
                ch
=getchar();
                
if(ch=='m')
                    man[m].x
=i,man[m].y=j,m++;
                
else if(ch=='H')
                    home[h].x
=i,home[h].y=j,h++;
            }

            getchar();
        }

        memset(map,
0,sizeof(map));
        
for(i=0;i<m;i++)
            
for(j=0;j<h;j++)
                map[i][j]
=abs(man[i].x-home[j].x)+abs(man[i].y-home[j].y);
        printf(
"%d\n",kuhn_munkras());
    }

    
return 0;
}

posted on 2009-06-03 12:45 極限定律 閱讀(824) 評論(0)  編輯 收藏 引用 所屬分類: ACM/ICPC

<2009年5月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

導航

統計

常用鏈接

留言簿(10)

隨筆分類

隨筆檔案

友情鏈接

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            午夜影院日韩| 午夜国产精品影院在线观看| 麻豆精品精华液| 午夜久久久久久| 国产日韩视频| 久久久www成人免费无遮挡大片| 午夜激情综合网| 国产欧美婷婷中文| 噜噜噜久久亚洲精品国产品小说| 欧美怡红院视频| 亚洲高清资源| 日韩亚洲欧美成人| 国产精品久久国产精麻豆99网站| 午夜久久电影网| 欧美在线免费播放| 亚洲国产美女精品久久久久∴| 欧美激情视频在线播放 | 亚洲精品视频免费| 国产精品久久影院| 久久一区中文字幕| 欧美精彩视频一区二区三区| 一区二区三区精品视频| 国产农村妇女精品一二区| 久久久精品国产一区二区三区| 久久精品在线视频| 在线亚洲自拍| 久久九九全国免费精品观看| 亚洲激情综合| 亚洲综合日韩| 亚洲国产毛片完整版 | 久久精品国产99精品国产亚洲性色 | 91久久精品国产91久久性色tv| 亚洲精选91| 国产综合在线看| 亚洲人体偷拍| 国产精品毛片大码女人| 欧美成人亚洲成人| 欧美性猛片xxxx免费看久爱 | 91久久精品一区二区别| 亚洲影院免费| 在线观看视频欧美| 亚洲综合另类| 一区二区三区精品国产| 久久永久免费| 欧美在线视频免费播放| 欧美理论片在线观看| 久久青草久久| 国产精品免费看久久久香蕉| 91久久视频| 在线日韩av永久免费观看| 在线视频精品一| 亚洲精品在线观看视频| 久久久久久久久久久一区| 亚洲男女毛片无遮挡| 欧美成人一品| 欧美激情亚洲激情| 亚洲第一区在线观看| 亚洲欧美激情在线视频| 亚洲永久视频| 欧美日韩国产精品| 亚洲精品123区| 亚洲二区精品| 玖玖精品视频| 欧美日韩亚洲综合| 欧美一级视频一区二区| 老色鬼精品视频在线观看播放| 一区二区三欧美| 一区二区av| 欧美精品福利| 亚洲国产欧美国产综合一区| 亚洲茄子视频| 久久综合国产精品台湾中文娱乐网| 欧美中日韩免费视频| 国产精品永久| 午夜视频在线观看一区二区三区 | 国产视频综合在线| 亚洲影视中文字幕| 午夜在线一区| 国产亚洲va综合人人澡精品| 欧美在线黄色| 欧美高清视频一区二区| 亚洲国产美女精品久久久久∴| 免费看精品久久片| 最近看过的日韩成人| 一区二区三区**美女毛片| 欧美日韩国产影片| 亚洲一二区在线| 久久久国产精品一区| 在线看成人片| 欧美看片网站| 亚洲综合三区| 免费久久99精品国产自在现线| 亚洲激情影视| 欧美色图五月天| 欧美在现视频| 亚洲黄色尤物视频| 亚洲免费视频一区二区| 国产一区清纯| 欧美国产一区二区三区激情无套| 一本高清dvd不卡在线观看| 欧美一区二区视频在线观看| 亚洲电影欧美电影有声小说| 欧美极品一区| 欧美一区1区三区3区公司| 欧美电影免费观看| 亚洲一区久久久| 黄色欧美日韩| 欧美调教vk| 麻豆91精品| 亚洲一区免费看| 亚洲第一久久影院| 欧美在线视频播放| 日韩网站在线观看| 国产一区美女| 欧美视频一区在线| 美女啪啪无遮挡免费久久网站| 中国成人黄色视屏| 亚洲国产成人久久综合| 久久精品99无色码中文字幕| 一本大道av伊人久久综合| 一区二区三区在线观看欧美| 欧美亚州一区二区三区 | 亚洲人成网站999久久久综合| 欧美一区二区三区成人| 日韩网站在线观看| 亚洲第一网站| 国产一区二区丝袜高跟鞋图片 | 亚洲欧美怡红院| 亚洲精品在线二区| 欧美成熟视频| 麻豆成人av| 久久www成人_看片免费不卡 | 国产精品亚洲网站| 欧美日产在线观看| 久热爱精品视频线路一| 久久成年人视频| 亚洲女同精品视频| 一区二区三区欧美日韩| 亚洲美女精品一区| 亚洲人成在线播放| 亚洲国产精品va| 蜜桃av久久久亚洲精品| 久久久91精品国产一区二区精品| 亚洲欧美日韩中文在线制服| 一区二区激情| 夜夜嗨av一区二区三区网站四季av| 在线播放日韩欧美| 伊人夜夜躁av伊人久久| 在线观看免费视频综合| 激情五月综合色婷婷一区二区| 国内外成人免费激情在线视频| 国产日韩亚洲欧美| 国内精品免费在线观看| 激情五月综合色婷婷一区二区| 国模套图日韩精品一区二区| 国产一区日韩欧美| 亚洲电影免费观看高清完整版在线| 激情成人在线视频| 亚洲电影第三页| 日韩一二三在线视频播| 一区二区三区av| 亚洲欧美激情一区| 欧美综合国产精品久久丁香| 久久9热精品视频| 久久久夜色精品亚洲| 美日韩免费视频| 亚洲精美视频| 亚洲视频在线观看视频| 羞羞答答国产精品www一本| 久久精品在线播放| 欧美精品国产精品日韩精品| 欧美午夜影院| 激情久久久久| 99一区二区| 欧美永久精品| 亚洲电影免费观看高清| 99亚洲一区二区| 欧美亚洲在线| 欧美成人四级电影| 国产精品人人做人人爽| 一区二区在线免费观看| 99精品久久久| 久久久久久色| 亚洲精品小视频| 午夜亚洲伦理| 欧美国产日韩a欧美在线观看| 国产精品久久激情| 亚洲国产婷婷香蕉久久久久久99| 在线一区欧美| 你懂的亚洲视频| 亚洲综合99| 欧美国产一区二区| 国产在线观看91精品一区| 亚洲裸体在线观看| 久久免费国产精品1| 一本色道久久综合亚洲精品按摩 | 亚洲免费久久| 久久久蜜桃一区二区人| 国产精品久久二区| aa国产精品|