hdu1533 费用流模板
Going Home
Time Limit: 10000/5000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)
Total Submission(s): 6114 Accepted Submission(s): 3211
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.
10
28
/*
Welcome Hacking
Wish You High Rating
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<ctime>
#include<cstdlib>
#include<algorithm>
#include<cmath>
#include<string>
using namespace std;
int read(){
int xx=0,ff=1;char ch=getchar();
while(ch>'9'||ch<'0'){if(ch=='-')ff=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){xx=(xx<<3)+(xx<<1)+ch-'0';ch=getchar();}
return xx*ff;
}
const int maxlongint=(1LL<<31)-1;
inline int myabs(int xx)
{if(xx<0)return -xx;return xx;}
inline int mymin(int xx,int yy)
{if(xx>yy)return yy;return xx;}
inline int mymax(int xx,int yy)
{if(xx>yy)return xx;return yy;}
int N,M,st,en;
int s1[110],s2[110],tp1,tp2,ans;
inline int get_id(int xx,int yy)
{return (xx-1)*M+yy;}
inline int get_dis(int id1,int id2){
int sx=id1/M,sy=id1%M,fx=id2/M,fy=id2%M;
if(!sy)
sx--,sy=M;
if(!fy)
fx--,fy=M;
return myabs(sx-fx)+myabs(sy-fy);
}
int lin[210],len;
struct edge{
int y,next,v,f;
}e[200010];
inline void insert(int xx,int yy,int ff,int vv){
e[++len].next=lin[xx];
lin[xx]=len;
e[len].y=yy;
e[len].v=vv;
e[len].f=ff;
}
inline void ins(int xx,int yy,int ff,int vv)
{insert(xx,yy,ff,vv),insert(yy,xx,0,-vv);}
void build(){
st=tp1+tp2+1,en=st+1;
memset(lin,0,sizeof(lin));len=0;
for(int i=1;i<=tp1;i++)
for(int j=1;j<=tp2;j++)
ins(i,j+tp1,1,get_dis(s1[i],s2[j]));
for(int i=1;i<=tp1;i++)
ins(st,i,1,0);
for(int j=1;j<=tp2;j++)
ins(j+tp1,en,1,0);
}
int q[1000010],head,tail,dis[210],Prev[210],useedge[210];
bool vis[210];
bool SPFA(){
memset(vis,0,sizeof(vis));
memset(dis,10,sizeof(dis));
head=tail=0;
q[head]=st;
vis[q[head]]=1;
dis[q[head]]=0;
for(;head<=tail;head++){
vis[q[head]]=0;
for(int i=lin[q[head]];i;i=e[i].next)
if(e[i].f)
if(dis[e[i].y]>dis[q[head]]+e[i].v){
dis[e[i].y]=dis[q[head]]+e[i].v;
if(!vis[e[i].y]){
vis[e[i].y]=1;
q[++tail]=e[i].y;
}
Prev[e[i].y]=q[head];
useedge[e[i].y]=i;
}
}
//printf("#%d#\n",dis[en]);
return dis[en]!=dis[0];
}
void agu(){
int add=maxlongint;
for(int i=en;i!=st;i=Prev[i]){
add=mymin(add,e[useedge[i]].f);
}
for(int i=en;i!=st;i=Prev[i]){
e[useedge[i]].f-=add;
if(useedge[i]&1)
e[useedge[i]+1].f+=add;
else
e[useedge[i]-1].f+=add;
ans+=add*e[useedge[i]].v;
}
}
void cost_flow(){
ans=0;
while(SPFA())
agu();
printf("%d\n",ans);
}
int main(){
//freopen("in","r",stdin);
//freopen("out","w",stdout);
while(1){
N=read(),M=read();
if((!N)&&(!M))
break;
tp1=tp2=0;
char tmp;
for(int i=1;i<=N;i++)
for(int j=1;j<=M;j++){
tmp=getchar();
while(tmp==10||tmp==32)
tmp=getchar();
if(tmp=='H')
s1[++tp1]=get_id(i,j);
else if(tmp=='m')
s2[++tp2]=get_id(i,j);
}
build();
cost_flow();
}
return 0;
}
hdu1533 费用流模板的更多相关文章
- HDU2686 费用流 模板
Matrix Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Subm ...
- HDU 6611 K Subsequence(Dijkstra优化费用流 模板)题解
题意: 有\(n\)个数\(a_1\cdots a_n\),现要你给出\(k\)个不相交的非降子序列,使得和最大. 思路: 费用流建图,每个点拆点,费用为\(-a[i]\),然后和源点连边,和后面非降 ...
- 费用流模板(带权二分图匹配)——hdu1533
/* 带权二分图匹配 用费用流求,增加源点s 和 汇点t */ #include<bits/stdc++.h> using namespace std; #define maxn 1000 ...
- 初识费用流 模板(spfa+slf优化) 餐巾计划问题
今天学习了最小费用最大流,是网络流算法之一.可以对于一个每条边有一个容量和一个费用(即每单位流的消耗)的图指定一个源点和汇点,求在从源点到汇点的流量最大的前提下的最小费用. 这里讲一种最基础也是最好掌 ...
- 算法复习——费用流模板(poj2135)
题目: Farm Tour Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 16898 Accepted: 6543 De ...
- Spfa费用流模板
; ,maxm=; ,fir[maxn],nxt[maxm],to[maxm]; int cap[maxm],val[maxm],dis[maxn],path[maxn]; void add(int ...
- zkw费用流模板
理论:http://www.cnblogs.com/acha/p/6735037.html #include<cstdio> #include<cstring> #includ ...
- 【费用流】【Next Array】费用流模板(spfa版)
#include<cstdio> #include<algorithm> #include<cstring> #include<queue> using ...
- 费用流 ZOJ 3933 Team Formation
题目链接 题意:两个队伍,有一些边相连,问最大组对数以及最多女生数量 分析:费用流模板题,设置两个超级源点和汇点,边的容量为1,费用为男生数量.建边不能重复建边否则会T.zkw费用流在稠密图跑得快,普 ...
随机推荐
- UltraEdit(UE)window破解方法
安装UltraEdit(一路下一步,无难点)成功后,打开软件弹出如下使用模式提示信息. 关掉UltraEdit软件,同时 断本机网络.重新打开UltraEdit软件: 点击[输入许可证密 ...
- pengyue-form 模块 dropdown 关系联动
<script> window.onload=function() { var school= document.getElementById("dnn_ctr5973_View ...
- java_io学习_编码
package io; public class encodingDemo{ public static void main(String[] args) throws Exception{ // T ...
- js 闭包 定时器
; !function (win) { ; //内部私有 , ; //内部私有 //test.prototype.tt1 = 0;//共有变量 var test = function () {}; t ...
- API 接口监控产品全新改版,免费开放全部功能
作为 EOLINKER 研发管理体系的重要一环,EOLINKER 接口监控即 AMT 产品将在 3月4日 迎来全新变化,AMT 产品将正式命名为 EOLINKER-API Beacon --API-烽 ...
- 详解proxy_pass、upstream与resolver
详解proxy_pass.upstream与resolver boldcautious 关注 2018.06.04 10:48 字数 1204 阅读 1434评论 0喜欢 2 应用场景 这里列举几个应 ...
- Eclipse调试DEBUG时快速查看某个变量的值的快捷键
ctrl+shift+i
- hadoop2.3.0cdh5.0.2 升级到cdh5.7.0
后儿就放假了,上班这心真心收不住,为了能充实的度过这难熬的两天,我决定搞个大工程.....ps:我为啥这么期待放假呢,在沙发上像死人一样躺一天真的有意义嘛....... 当然版本:hadoop2.3. ...
- asp.net--mvc--异步编程
Using Asynchronous Methods in ASP.NET MVC 4 asp.net mvc中的异步只能增加系统的性能,原来需要500个线程的,现在需要50个就够了,对一些常规的程序 ...
- [bzoj2850]巧克力王国_KD-Tree
巧克力王国 bzoj-2850 题目大意:给出n块巧克力,每块巧克力都有自己的两个参数x和y和本身的价值val,询问:m个人,每个人有两个系数和一个限度a,b,和c.求所有ax+by<=c的巧克 ...