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

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

二、分析
      一個簡單的最優匹配問題,但要注意它要求的是最小權匹配,可以改成最大權匹配(第57行)用KM算法,詳細算法:匹配問題
三、代碼
 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 閱讀(692) 評論(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>
            一区二区冒白浆视频| 久久久久se| 国产精品国产三级国产专区53| 欧美不卡视频| 欧美三级电影一区| 国产精品入口尤物| 一区二区三区在线免费播放| 在线免费观看欧美| 国产精品99久久99久久久二8| 亚洲一区二区免费| 欧美一区二区啪啪| 欧美激情亚洲视频| 亚洲视频一区二区免费在线观看| 亚洲欧美国产日韩天堂区| 香蕉久久国产| 欧美激情精品久久久久久大尺度 | 美女日韩欧美| 亚洲欧洲免费视频| 亚洲欧美区自拍先锋| 久久久97精品| 国产精品观看| 亚洲日本免费| 久久久精品五月天| 亚洲理论在线观看| 亚洲毛片播放| 好吊色欧美一区二区三区四区 | 欧美视频成人| 欧美成人免费在线视频| 久久久久久久波多野高潮日日| 亚洲一区二区成人| 久久久国产91| 亚洲精品裸体| 欧美韩日亚洲| 午夜精品国产更新| 欧美成人精品1314www| 国产精品视频一二| 亚洲免费观看视频| 蜜桃av噜噜一区二区三区| 一本大道久久a久久综合婷婷| 久久精品噜噜噜成人av农村| 国产精品theporn| 亚洲日本中文字幕区| 久久九九精品99国产精品| 亚洲精选一区二区| 免费亚洲电影| 激情久久中文字幕| 久久精品日产第一区二区| 亚洲一区二区三区在线播放| 欧美成人午夜视频| 一区二区三区在线高清| 久久xxxx精品视频| 国产精品99久久久久久人| 欧美国产日韩免费| 亚洲人成亚洲人成在线观看| 久久精彩免费视频| 亚洲一区久久| 欧美日韩在线观看一区二区| 91久久综合亚洲鲁鲁五月天| 麻豆免费精品视频| 久久婷婷av| 亚洲国产欧美一区二区三区同亚洲 | 欧美国产日韩在线观看| 国语自产偷拍精品视频偷| 欧美专区在线播放| 欧美专区日韩视频| 极品中文字幕一区| 欧美电影在线免费观看网站| 麻豆av一区二区三区久久| 91久久久久久国产精品| 亚洲免费观看| 国产精品捆绑调教| 久久精品麻豆| 久久亚洲私人国产精品va| 亚洲第一精品久久忘忧草社区| 亚洲国产精品第一区二区| 欧美成人影音| 国产精品va在线播放| 亚洲欧美99| 亚洲一区二区三区成人在线视频精品 | 国产精品日韩欧美| 夜夜嗨av色综合久久久综合网| 欧美成人一区二区三区| 久久久久久午夜| 亚洲激精日韩激精欧美精品| 浪潮色综合久久天堂| 亚洲欧美国产精品桃花| 99国产精品视频免费观看一公开| 国产精品高潮呻吟久久av无限| 午夜精品福利电影| 久久久国产精品一区| 最新69国产成人精品视频免费| 最新成人在线| 国产欧美一区二区三区在线老狼| 久热精品在线视频| 欧美日韩另类丝袜其他| 性欧美video另类hd性玩具| 久久综合色影院| 亚洲午夜精品久久| 久久久久久久999精品视频| 免费观看日韩| 亚洲欧美在线播放| 久久一区激情| 一区二区三区产品免费精品久久75 | 久久精品国产69国产精品亚洲| 久久在线免费观看视频| 一本一本a久久| 久久精品理论片| 亚洲免费伊人电影在线观看av| 午夜天堂精品久久久久| 欧美在线免费播放| 亚洲欧美高清| 欧美精品一区在线| 欧美aaa级| 国产亚洲欧美日韩精品| 中国成人黄色视屏| 99在线精品视频| 久久久精品动漫| 午夜影院日韩| 欧美日韩亚洲激情| 亚洲精品免费在线| 精品88久久久久88久久久| 中日韩美女免费视频网址在线观看 | 亚洲一区二区在线播放| 亚洲国产高清aⅴ视频| 性欧美大战久久久久久久久| 亚洲一区二区在线播放| 欧美精品久久99久久在免费线| 免费在线成人av| 狠狠狠色丁香婷婷综合激情| 翔田千里一区二区| 欧美一区二区三区免费看| 欧美日韩一区二区三区在线| 亚洲国产成人在线| 亚洲激情图片小说视频| 久久久夜夜夜| 免费欧美视频| 亚洲激情在线观看视频免费| 久久人人看视频| 欧美成人免费一级人片100| 国产日韩欧美一区| 99视频一区| 亚洲午夜激情| 国产九九精品| 亚洲综合色视频| 欧美亚洲在线| 狠狠干综合网| 欧美韩日一区| av成人福利| 一本色道久久综合亚洲二区三区| 欧美另类女人| 在线综合亚洲欧美在线视频| 午夜性色一区二区三区免费视频| 国产欧美在线观看| 久久夜色精品| 亚洲免费精品| 欧美在线视频日韩| 国产综合久久久久久鬼色| 久久久久久久久伊人| 亚洲国产精品成人精品| 中文精品在线| 国产丝袜美腿一区二区三区| 狼狼综合久久久久综合网 | 在线免费观看视频一区| 欧美成人精品激情在线观看| 亚洲理论在线观看| 欧美中文在线观看| 亚洲国产精品一区二区三区| 欧美日韩精品一区二区三区四区| 亚洲性图久久| 欧美国产在线观看| 亚洲社区在线观看| 国产一区二区三区四区三区四| 美女主播精品视频一二三四| 亚洲最新视频在线| 榴莲视频成人在线观看| 亚洲一区二区三区精品动漫| 激情校园亚洲| 国产精品久久久久影院亚瑟| 狂野欧美性猛交xxxx巴西| 亚洲一区二区三区影院| 亚洲国产精品va在线看黑人 | 久久亚洲不卡| 亚洲精品日韩在线| 国产精品一区二区你懂得| 久久精品1区| 99re热这里只有精品免费视频| 久久久久99| 亚洲欧美精品在线| 亚洲精品久久久久中文字幕欢迎你| 国产精品久久久久久久浪潮网站 | 午夜精品福利一区二区三区av| 亚洲第一免费播放区| 久久爱www| 欧美一区二区三区四区在线观看地址 | 亚洲日本成人| 女同一区二区| 久久女同互慰一区二区三区| 香蕉成人啪国产精品视频综合网| av成人免费在线观看| 亚洲国产欧美不卡在线观看|