题目:http://poj.org/problem?id=2195

有若干个人和若干个房子在一个给定网格中,每人走一个都要一定花费,每个房子只能容纳一人,现要求让所有人进入房子,且总花费最小。

构造一个超级源s和超级汇t,超级源s与U中所有点相连,费用cost[s][u]=0(这是显然的),容量cap[s][u]=1;V中所有点与超级汇t相连,

费用cost[v][t]=0(这是显然的),容量cap[t][v]=1。

 #include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <algorithm>
#include <queue>
#include <vector>
#include <cmath>
using namespace std;
const int INF=<<;
const int maxn=;
struct node
{
int x,y;
}p[maxn],h[maxn];
int c[maxn][maxn],f[maxn][maxn],w[maxn][maxn];
int n,m,pn,hn,s,t,ans;
bool inq[maxn]; //是否在队列中
char str[maxn][maxn];
int pre[maxn],dis[maxn];//上一条弧,Bellman_ford; void spfa()
{
int i,v;
queue<int>q;
for (i = ; i < maxn; i++)
{
dis[i] = INF;
pre[i] = -;
inq[i] = false;
}
q.push(s);
inq[s] = true;
dis[s] = ;
while (!q.empty())
{
int u = q.front();
q.pop();
inq[u] = false;
for (v = ; v <= t; v++)
{
if (c[u][v]&& dis[v] > dis[u] + w[u][v])
{
dis[v] = dis[u] + w[u][v];
pre[v] = u;
if (!inq[v])
{
q.push(v);
inq[v] = true;
}
}
}
}
}
void mcmf()
{
while ()
{
spfa();
if (pre[t] == -) break;
int x = t,minf = INF;
while (pre[x] != -)
{
minf = min(minf,c[pre[x]][x]);
x = pre[x];
}
x = t;
while (pre[x] != -)
{
c[pre[x]][x]-=minf;
c[x][pre[x]]+=minf;
ans+=minf*w[pre[x]][x];
x = pre[x];
}
}
} int main()
{
int i,j,pn,hn;
while(cin>>n>>m && n || m)
{
pn = hn = ;
memset(c,,sizeof(c));
memset(f,,sizeof(f));
memset(w,,sizeof(w));
for(i = ; i < n; i++)
{
scanf("%s",str[i]);
for(j = ; j < m; j++)
{
if(str[i][j] == 'H')
{
h[++hn].x = i;
h[hn].y = j;
}
else if(str[i][j] == 'm')
{
p[++pn].x = i;
p[pn].y = j;
}
}
}
s = ;
t = pn + hn + ;
for (i = ; i <= pn; i++)
c[s][i] = ;
for (i = ; i <= hn; i++)
c[i + pn][t] = ;
for (i = ; i <= pn; i++)
{
for (j = ; j <= hn; j++)
{
c[i][j + pn] = ;
w[i][j + pn] = abs(p[i].x - h[j].x) + abs(p[i].y - h[j].y);
w[j + pn][i] = -w[i][j + pn];
} }
ans = ;
mcmf();
printf("%d\n",ans);
}
return ;
}

poj 2195 Going Home(最小费用最大流)的更多相关文章

  1. POJ 2195 - Going Home - [最小费用最大流][MCMF模板]

    题目链接:http://poj.org/problem?id=2195 Time Limit: 1000MS Memory Limit: 65536K Description On a grid ma ...

  2. POJ 2195 Going Home 最小费用最大流 尼玛,心累

    D - Going Home Time Limit:1000MS     Memory Limit:65536KB     64bit IO Format:%I64d & %I64u Subm ...

  3. poj 2351 Farm Tour (最小费用最大流)

    Farm Tour Time Limit: 1000MS   Memory Limit: 65536K Total Submissions: 17230   Accepted: 6647 Descri ...

  4. POJ 2157 Evacuation Plan [最小费用最大流][消圈算法]

    ---恢复内容开始--- 题意略. 这题在poj直接求最小费用会超时,但是题意也没说要求最优解. 根据线圈定理,如果一个跑完最费用流的残余网络中存在负权环,那么顺着这个负权环跑流量为1那么会得到更小的 ...

  5. poj 2135 Farm Tour 最小费用最大流建图跑最短路

    题目链接 题意:无向图有N(N <= 1000)个节点,M(M <= 10000)条边:从节点1走到节点N再从N走回来,图中不能走同一条边,且图中可能出现重边,问最短距离之和为多少? 思路 ...

  6. POJ 3680: Intervals【最小费用最大流】

    题目大意:你有N个开区间,每个区间有个重量wi,你要选择一些区间,使得满足:每个点被不超过K个区间覆盖的前提下,重量最大 思路:感觉是很好想的费用流,把每个区间首尾相连,费用为该区间的重量的相反数(由 ...

  7. POJ 2135 Farm Tour [最小费用最大流]

    题意: 有n个点和m条边,让你从1出发到n再从n回到1,不要求所有点都要经过,但是每条边只能走一次.边是无向边. 问最短的行走距离多少. 一开始看这题还没搞费用流,后来搞了搞再回来看,想了想建图不是很 ...

  8. [poj] 1235 Farm Tour || 最小费用最大流

    原题 费用流板子题. 费用流与最大流的区别就是把bfs改为spfa,dfs时把按deep搜索改成按最短路搜索即可 #include<cstdio> #include<queue> ...

  9. POJ 2516 Minimum Cost [最小费用最大流]

    题意略: 思路: 这题比较坑的地方是把每种货物单独建图分开算就ok了. #include<stdio.h> #include<queue> #define MAXN 500 # ...

随机推荐

  1. @+id/和android:id的区别

    android:id="@+id/btn",表示在R.java文件里面新增一个id为btn的控件索引,最常用的一种声明控件id的方式.android:id="@andro ...

  2. N皇后问题2

    Description Examine the  checkerboard below and note that the six checkers are arranged on the board ...

  3. 种子填充找连通块 floodfill

    Description Due to recent rains, water has pooled in various places in Farmer John's field, which is ...

  4. Servlet一次乱码排查后的总结(转)

    原文地址:http://my.oschina.net/looly/blog/287255 由来 在写一个小小的表单提交功能的时候,出现了乱码,很奇怪request上来的参数全部是乱码,而从数据库查询出 ...

  5. C#网络编程(1)

    1.Purpose 1.什么是网络编程 2.TCP/IP协议 3.什么是套接字 4.多线程深入理解 二.Basic Concept 1.网络编程:主要实现进程(线程)相互之间的通信和基本的网络应用原理 ...

  6. 统计网卡TX(发送)RX(接受)流量脚本

    显示网卡流量的方法蛮多,一般我们可以通过dstat来查看,但dstat不一定所有的机器都有安装.而我们知道,通过ifconfig可以看到某一网卡发送与接收的字节数,所以我们可以写一个脚本来统计一下. ...

  7. 【BZOJ 2038】[2009国家集训队]小Z的袜子(hose)

    Description HH有一串由各种漂亮的贝壳组成的项链.HH相信不同的贝壳会带来好运,所以每次散步 完后,他都会随意取出一段贝壳,思考它们所表达的含义.HH不断地收集新的贝壳,因此, 他的项链变 ...

  8. python学习笔记29(python中堆的使用)

    堆(heap):优先队列的一种,使用优先队列能够以任意顺序增加对象,并且能在任意时间(可能在增加对象的同时)找到(也可能是移除)最小元素,比用于列表中min的方法要高效. Python中并没有独立的堆 ...

  9. C#学习笔记---基础入门(二)

    枚举 枚举是被命名的整型常数的集合:枚举类型的变量只有赋值后才能使用:不同枚举中的枚举值可以重名:可以自定义枚举值. enum Playstates {            跑, 跳,下滑,左转,右 ...

  10. mybatis 的<![CDATA[ ]]>

    示例: xml文件: <!-- 获取条数 --> <select id="getCount" parameterType="Map" resu ...