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

posts - 18,  comments - 5,  trackbacks - 0
一、題目描述

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

二、分析
      一個簡單的最優(yōu)匹配問題,但要注意它要求的是最小權(quán)匹配,可以改成最大權(quán)匹配(第57行)用KM算法,詳細(xì)算法:匹配問題
三、代碼
 1#include<iostream>
 2#include<cmath>
 3using namespace std;
 4int n, m;
 5char str[101];
 6int hc, home[100][2];
 7int mc, man[100][2];
 8int map[100][100];
 9int lx[100], ly[100];
10int mat[100];
11bool vx[100], vy[100];
12int  slack[100];
13bool dfs(int u)
14{
15    vx[u] = true;
16    for(int v=0; v<mc; v++)
17    {
18        if(!vy[v] && lx[u]+ly[v] == map[u][v])
19        {
20            vy[v] = true;
21            if(mat[v]==-1 || dfs(mat[v]))
22            {
23                mat[v] = u;
24                return true;
25            }

26        }

27        else if(lx[u]+ly[v] > map[u][v])
28            slack[v] = min(slack[v], lx[u] + ly[v] - map[u][v]);
29    }

30    return false;
31}

32int main()
33{
34    while(1)
35    {
36        scanf("%d%d"&n, &m);
37        if(n==0 && m==0)
38            break;
39        hc = mc = 0;
40        for(int i=0; i<n; i++)
41        {
42            scanf("%s", str);
43            for(int j=0; j<m; j++)
44            {
45                if(str[j] == 'H')
46                {
47                    home[hc][0= i; home[hc++][1= j;
48                }

49                else if(str[j] == 'm')
50                {
51                    man[mc][0= i; man[mc++][1= j;
52                }

53            }

54        }

55        for(int i=0; i<mc; i++)
56            for(int j=0; j<mc; j++)
57                map[i][j] = 200 - abs(man[i][0]-home[j][0]) - abs(man[i][1]-home[j][1]);
58        memset(lx, 0sizeof(lx));
59        memset(ly, 0sizeof(ly));
60        for(int u=0; u<mc; u++)
61            for(int v=0; v<hc; v++)
62                lx[u] = max(lx[u], map[u][v]);
63        memset(mat, -1sizeof(mat));
64        for(int u=0; u<mc; u++)
65        {
66            while(1)
67            {
68                memset(vx, 0sizeof(vx));
69                memset(vy, 0sizeof(vy));
70                for(int j=0; j<mc; j++)
71                    slack[j] = INT_MAX;
72                if(dfs(u))
73                    break;
74                int al = INT_MAX;
75                for(int i=0; i<mc; i++)
76                    if(!vy[i])
77                        al = min(al, slack[i]);
78                for(int i=0; i<mc; i++)
79                {
80                    if(vx[i]) lx[i] -= al;
81                    if(vy[i]) ly[i] += al;
82                }

83            }

84        }

85        int res = 0;
86        for(int v=0; v<mc; v++)
87            res += 200 - map[mat[v]][v];
88        printf("%d\n", res);
89    }

90}
posted on 2009-06-29 14:42 Icyflame 閱讀(698) 評論(0)  編輯 收藏 引用 所屬分類: 解題報告
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美a级片一区| 香港久久久电影| 亚洲国产精品一区二区www在线| 亚洲一区欧美| 国产农村妇女毛片精品久久麻豆| 亚洲视频综合| 亚洲欧美999| 国产一区二区三区成人欧美日韩在线观看| 欧美影院在线播放| 久久久人成影片一区二区三区观看 | 1769国内精品视频在线播放| 久久亚洲视频| 欧美国产先锋| 亚洲欧美在线看| 亚洲欧美高清| 在线观看欧美日韩| 亚洲精品久久久久久久久久久久| 欧美日韩黄视频| 欧美一区二区三区在线视频| 欧美淫片网站| 一区二区高清| 欧美专区18| 99天天综合性| 欧美中文字幕| 在线性视频日韩欧美| 欧美一区二区在线播放| 亚洲精品综合久久中文字幕| 亚洲一区二区三区激情| 在线视频成人| 亚洲欧美日韩国产中文| 亚洲精品在线免费观看视频| 亚洲一区二区三区精品在线| 精品成人在线观看| 亚洲一区二区精品在线观看| 亚洲国产成人91精品| 亚洲一区综合| 一区二区三区高清在线| 久久久91精品国产| 亚洲欧美日韩一区在线| 欧美成人在线影院| 久久久精品动漫| 欧美三级电影一区| 亚洲国产精品福利| 韩日午夜在线资源一区二区| 正在播放欧美视频| 日韩一区二区高清| 男人天堂欧美日韩| 免费观看30秒视频久久| 国产一区二区三区四区hd| 一区二区精品国产| 妖精成人www高清在线观看| 久久人人爽人人爽爽久久| 香蕉尹人综合在线观看| 欧美午夜精品一区二区三区| 亚洲狠狠丁香婷婷综合久久久| 国产伦精品一区二区三区高清| 日韩午夜免费| 一区二区三区欧美| 欧美国产极速在线| 亚洲国产精品一区二区www| 极品中文字幕一区| 久久国产99| 久久亚洲综合色| 激情欧美日韩一区| 久久嫩草精品久久久精品| 欧美专区在线播放| 国产精品一区二区a| 亚洲永久精品大片| 久久精品国产亚洲aⅴ| 国产日本欧美一区二区三区在线| 亚洲香蕉伊综合在人在线视看| 在线视频精品一| 欧美日韩在线视频一区| 9l视频自拍蝌蚪9l视频成人| 亚洲视屏一区| 国产女精品视频网站免费| 亚洲欧美在线免费| 久久久久国产精品一区二区| 国内精品久久久久久影视8| 欧美一区二区啪啪| 美女精品在线观看| 亚洲精品日韩激情在线电影| 欧美日韩美女在线| 日韩一级片网址| 欧美一区久久| 在线观看一区欧美| 欧美日韩成人在线观看| 亚洲天堂av在线免费观看| 欧美一区二区三区在线视频 | 久久精品综合一区| 欧美国产亚洲另类动漫| 日韩亚洲国产欧美| 国产视频一区在线| 免费久久99精品国产自在现线| 亚洲精选一区| 久久精品三级| 99国内精品久久| 国产欧美精品一区二区色综合 | 久久久国产精品一区二区三区| 欧美激情aⅴ一区二区三区| 亚洲一区二区高清| 一区免费视频| 欧美小视频在线观看| 久久久欧美精品sm网站| 一区二区日韩| 欧美不卡视频| 欧美亚洲自偷自偷| 亚洲日本欧美日韩高观看| 国产美女一区| 欧美日韩国产123| 久久另类ts人妖一区二区| 正在播放欧美一区| 亚洲国产精品嫩草影院| 久久精品国产一区二区三区| 夜夜爽av福利精品导航| 狠狠操狠狠色综合网| 国产精品国产a级| 美女黄色成人网| 欧美在线免费视屏| 亚洲影音一区| 一本色道久久综合亚洲精品不卡 | 女生裸体视频一区二区三区| 中文在线不卡视频| 亚洲国产欧美一区二区三区久久| 国产嫩草影院久久久久 | 久久国产精品久久久| 夜夜嗨av一区二区三区四区| 欧美激情麻豆| 欧美国产日韩视频| 久久综合九色综合欧美就去吻 | 国产区在线观看成人精品| 欧美美女操人视频| 女人天堂亚洲aⅴ在线观看| 欧美专区在线| 欧美一区二区三区在线免费观看| 亚洲色图制服丝袜| 99re66热这里只有精品4| 91久久亚洲| 亚洲激情av在线| 亚洲国产高清在线观看视频| 久热精品在线视频| 老司机精品久久| 久久婷婷av| 蜜臀久久久99精品久久久久久| 久久久青草青青国产亚洲免观| 欧美一区二区三区日韩视频| 亚洲欧美日韩在线一区| 午夜视频久久久| 欧美亚洲一区三区| 久久成人免费网| 久久久久天天天天| 免费在线成人av| 美女尤物久久精品| 欧美va亚洲va国产综合| 欧美黑人在线播放| 亚洲日产国产精品| 夜夜嗨av一区二区三区四区| 中国成人黄色视屏| 亚洲欧美日韩国产另类专区| 亚洲亚洲精品在线观看| 亚洲与欧洲av电影| 久久精品一级爱片| 欧美高清视频一区| 欧美日韩在线播放| 国产精品私人影院| 精品91视频| 一级成人国产| 欧美在线看片a免费观看| 模特精品裸拍一区| 日韩视频一区二区三区在线播放免费观看 | 欧美亚洲综合另类| 久久男女视频| 欧美日韩国产天堂| 国产欧美视频一区二区| 狠狠久久婷婷| 一区二区三区高清不卡| 欧美一区二区在线观看| 欧美va亚洲va日韩∨a综合色| 亚洲精品国产精品久久清纯直播| 一区二区av| 久久久久久午夜| 欧美精品v国产精品v日韩精品 | 久久亚洲综合色| 欧美国产日韩一区二区在线观看 | 久久超碰97中文字幕| 欧美激情第三页| 国产日韩欧美综合一区| 亚洲高清二区| 亚洲欧美日韩网| 欧美国产极速在线| 亚洲综合日韩| 欧美日韩国产欧| 黄色成人片子| 午夜精品在线| 亚洲国产美女精品久久久久∴| 亚洲综合色在线| 欧美日本中文| 亚洲高清av在线| 久久九九免费视频| 一本色道久久88亚洲综合88|