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

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年6月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

導航

統計

常用鏈接

留言簿(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>
            久久综合九色综合欧美就去吻| 老司机久久99久久精品播放免费 | 亚洲欧美国产精品专区久久| 日韩一级裸体免费视频| 欧美日韩免费高清一区色橹橹| 一区二区三区视频观看| 亚洲色图制服丝袜| 国产美女扒开尿口久久久| 久久国产精品一区二区| 久久综合伊人77777麻豆| 最新成人在线| 一区二区成人精品| 国产精品自拍小视频| 久久人人97超碰精品888| 美女网站在线免费欧美精品| 亚洲伦理精品| 亚洲视频免费在线观看| 经典三级久久| 99精品欧美一区| 国产亚洲欧美日韩日本| 91久久夜色精品国产九色| 欧美色大人视频| 久久午夜激情| 欧美日韩中文在线观看| 老司机67194精品线观看| 欧美华人在线视频| 久久精品99久久香蕉国产色戒| 久久综合九色综合网站| 亚洲欧美中文另类| 老司机免费视频一区二区| 亚洲综合另类| 免费不卡视频| 久久精品国产99精品国产亚洲性色| 免费亚洲一区二区| 久久久不卡网国产精品一区| 欧美日本免费| 欧美成人精品不卡视频在线观看| 欧美日韩直播| 亚洲国产精品日韩| 欲香欲色天天天综合和网| 中文在线资源观看网站视频免费不卡 | 国产精品v日韩精品v欧美精品网站| 欧美一区在线直播| 欧美日韩视频在线观看一区二区三区| 久久午夜电影| 国产欧美一区二区三区国产幕精品| 欧美激情综合| 樱桃国产成人精品视频| 亚洲一区二区三区精品视频| 一本色道88久久加勒比精品| 久久久噜噜噜久久久| 久久精品成人| 国产精品网站一区| 亚洲午夜精品一区二区三区他趣| 99热免费精品在线观看| 另类综合日韩欧美亚洲| 美女免费视频一区| 国产专区欧美精品| 亚洲欧美日韩综合aⅴ视频| 亚洲欧美日韩国产中文| 欧美视频一区二区三区| 亚洲靠逼com| 在线亚洲自拍| 国产精品成人一区二区网站软件 | 亚洲欧美综合一区| 亚洲永久在线| 国产精品vvv| 一本一本久久a久久精品综合妖精| 99精品欧美一区二区三区综合在线 | 亚洲欧美激情视频| 国产精品盗摄久久久| 一区二区日韩伦理片| 亚洲欧美成人网| 国产美女精品免费电影| 午夜欧美理论片| 久久婷婷av| 亚洲日本中文字幕免费在线不卡| 欧美1区2区3区| 日韩午夜在线播放| 性欧美大战久久久久久久免费观看 | 欧美精品久久一区二区| 亚洲激情在线观看视频免费| 亚洲每日更新| 国产精品久久久久久久电影| 亚洲综合色网站| 久久综合网hezyo| 亚洲开发第一视频在线播放| 欧美激情国产日韩精品一区18| 亚洲精品久久7777| 午夜亚洲伦理| 伊人一区二区三区久久精品| 欧美va天堂va视频va在线| 亚洲毛片视频| 久久精品国产69国产精品亚洲| 亚洲高清视频在线| 国产精品国产一区二区| 久久gogo国模裸体人体| 亚洲欧洲一二三| 欧美在线网站| 亚洲免费av网站| 国产日韩欧美在线播放不卡| 久久亚洲国产成人| 一本久久综合亚洲鲁鲁| 久久午夜激情| 亚洲综合精品四区| 亚洲激情不卡| 国产欧美欧美| 欧美日韩精品久久久| 久久精品99国产精品酒店日本| 亚洲精品视频在线观看免费| 久久精品91久久久久久再现| 一二三四社区欧美黄| 激情欧美日韩| 国产日韩一区欧美| 欧美日本国产在线| 久久综合九色欧美综合狠狠| 亚洲综合日韩| av72成人在线| 亚洲激情影院| 欧美顶级大胆免费视频| 久久精品最新地址| 性娇小13――14欧美| 99精品视频免费全部在线| 精品电影一区| 国产亚洲日本欧美韩国| 欧美性色综合| 欧美日本韩国| 欧美激情一区二区在线 | 小嫩嫩精品导航| 艳妇臀荡乳欲伦亚洲一区| 亚洲国产精品久久久久秋霞蜜臀| 久久在精品线影院精品国产| 亚洲欧美成人网| 亚洲一区区二区| 亚洲视频网在线直播| 亚洲免费成人av电影| 亚洲精品免费一区二区三区| 在线播放精品| 在线欧美视频| 在线精品观看| 亚洲高清av| 亚洲国产小视频在线观看| 在线精品一区| 亚洲国产日韩欧美在线99| 伊人久久综合| 91久久在线观看| 亚洲黄一区二区三区| 亚洲精品免费在线播放| 亚洲精品一区二区在线| 亚洲精品视频一区| 一本色道久久综合| 亚洲欧美在线观看| 欧美专区一区二区三区| 久久久噜噜噜久久狠狠50岁| 老牛国产精品一区的观看方式| 久久久伊人欧美| 欧美成人一区二区在线| 亚洲激情第一区| 亚洲视频网在线直播| 亚洲欧美日韩国产一区二区三区| 欧美永久精品| 欧美成年人视频网站| 欧美日韩在线不卡| 国产欧美日韩91| 亚洲高清不卡av| 亚洲系列中文字幕| 久久久国产视频91| 欧美国产精品v| 一本一本久久| 久久久久国产精品一区三寸| 欧美韩国日本综合| 国产精品视频久久一区| 激情国产一区二区| 在线综合欧美| 久久久久一区二区三区四区| 亚洲高清视频中文字幕| 亚洲图片欧洲图片av| 久久精品视频导航| 欧美日韩在线一区| 狠狠色2019综合网| 亚洲天堂成人在线视频| 久久色中文字幕| 99国内精品久久| 久久永久免费| 国产精品成人观看视频免费 | 激情六月婷婷久久| 夜夜嗨av一区二区三区四季av| 欧美在线观看一区二区| 亚洲福利电影| 欧美一区在线直播| 欧美三级不卡| 亚洲国产精品激情在线观看| 亚洲欧美色一区| 亚洲激情精品| 久久免费黄色| 国产亚洲欧美在线| 午夜久久福利| 亚洲毛片一区二区| 欧美多人爱爱视频网站| 国内精品伊人久久久久av影院|