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费用流在稠密图跑得快,普 ...
随机推荐
- CSS——行高
浏览器默认文字大小:16px 行高:是基线与基线之间的距离 行高=文字高度+上下边距 一行文字行高和父元素高度一致的时候,垂直居中显示. <!DOCTYPE html> <html& ...
- HDU_1027_Ignatius and the Princess II_全排列
Ignatius and the Princess II Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K ( ...
- std::vector遍历
std::vector是我在标准库中实用最频繁的容器.总结一下在遍历和创建vector时需要注意的一些地方. 在不考虑线程安全问题的前提下,在C++11中有五种遍历方式. 方式一 for (size_ ...
- table头部固定,内容滚动
可以设置两个table,th,td得设置宽度: <table> <thead> <tr><th></th&g ...
- profiler-gpu分析记录
查看 Android 手机芯片信息下面以 夜神模拟器为例 D:\cmderλ adb devices # 1. 列出安卓设备List of devices attached127.0.0.1:6200 ...
- Navicat 连接docker mysql报错
解决办法: docker exec -it dc10e8b328d7 bashmysql -u root -p 输入密码 use mysql; ALTER USER 'root'@'%' IDENTI ...
- postgresql数据库部署
运维开发技术交流群欢迎大家加入一起学习(QQ:722381733) 一.postgresql数据库部署 1.前往postgresql安装包的目录(这里我部署的是10.5的版本) [root@web1 ...
- 单例模式的python实现
# 本实例主要介绍单例模式 # 1.什么是单例模式 # 1. 确保有且只有一个对象被创建 # 2. 为对象提供一个访问点,以使程序可以全局访问该对象 # 3. 控制共享资源的并行访问 # 2.单例模式 ...
- camera placement (paraview)
# 'renderView1' is the view name# current camera placement for renderView1 renderView1.CameraPositio ...
- 并发通信Manage,队列, 互斥锁
目录 Manage 队列 先入先出 互斥锁 Manage 进程间的通信是被限制的 from multiprocessing import Process a = 1 def func(): glob ...