poj-2195-Going Home最小费用最大流
重新切一遍最小费用最大流~~~
这到题目的数据范围有问题,尽量开大就好了~~
#include<stdio.h>
#include<iostream>
#include<algorithm>
#include<string.h>
#include<queue>
using namespace std;
#define INF 999999
struct list
{
int u;
int v;
int next;
}node[1000001];
int num;
int head[1001];
int cost[1001][1001];
void add(int l,int r,int v)
{
node[num].u=r;
node[num].v=v;
node[num].next=head[l];
head[l]=num++;
}
int nos;
int juli(int x,int y,int m)
{
return abs(y/m-x/m)+abs(y%m-x%m);
}
int pre[1001];
int bfs()
{
int visit[1001];
int dist[1001];
int i;
for(i=0;i<=nos;i++)dist[i]=INF;
memset(visit,0,sizeof(visit));
memset(pre,-1,sizeof(pre));
queue<int>q;
q.push(0);
visit[0]=1;
dist[0]=0;
while(!q.empty())
{
int e=q.front();
q.pop();
//cout<<"弹"<<" "<<e<<endl;
visit[e]=0;
for(i=head[e];i!=-1;i=node[i].next)
{
int r=node[i].u;
if(dist[e]+node[i].v<dist[r]&&cost[e][r])
{
pre[r]=e;
dist[r]=dist[e]+node[i].v;
// printf("pre[%d]=%d,dist[%d]=%d\n",r,e,r,dist[r]);
if(!visit[r])
{
q.push(r);
// cout<<"入"<<" "<<r<<endl;
visit[r]=1;
}
}
}
}
if(dist[nos]!=INF)return 1;
return 0;
}
void change()
{
int minx;
minx=INF;
int i;
for(i=nos;pre[i]!=-1;i=pre[i])
{
minx=min(minx,cost[pre[i]][i]);
}
for(i=nos;pre[i]!=-1;i=pre[i])
{
cost[pre[i]][i]-=minx;
cost[i][pre[i]]+=minx;
}
}
int main()
{
int i,j,m,n;
char str[100001];
while(scanf("%d%d%*c",&n,&m)&&(n||m))
{
memset(head,-1,sizeof(head));
memset(cost,0,sizeof(cost));
int hm,mm;
hm=mm=0;
int ms[100001];
int hs[100001];
for(i=0;i<n;i++)
{
scanf("%s",str);
for(j=0;j<m;j++)
{
if(str[j]=='m')ms[++mm]=i*m+j;
else if(str[j]=='H')hs[++hm]=i*m+j;
}
getchar();
}
nos=hm+mm+1;
for(i=1;i<=mm;i++)
{
add(0,i,0);
add(i,0,0);
cost[0][i]=1;
cost[i][0]=0;
}
for(j=1;j<=hm;j++)
{
add(j+mm,mm+hm+1,0);
add(mm+hm+1,j+mm,0);
cost[j+mm][mm+hm+1]=1;
cost[mm+hm+1][j+mm]=0;
}
for(i=1;i<=mm;i++)
{
for(j=1;j<=hm;j++)
{
int ju=juli(ms[i],hs[j],m);
add(i,j+mm,ju);
add(j+mm,i,-ju);
cost[i][j+mm]=INF;
cost[j+mm][i]=0;
}
}
while(bfs())
{
change();
//cout<<"------------------------------------"<<endl;
}
int sum=0;
for(i=1;i<=mm;i++)
for(j=1;j<=hm;j++)
{
sum+=(INF-cost[i][j+mm])*juli(ms[i],hs[j],m);
}
cout<<sum<<endl;
}
return 0;
}
poj-2195-Going Home最小费用最大流的更多相关文章
- POJ 2195 - Going Home - [最小费用最大流][MCMF模板]
题目链接:http://poj.org/problem?id=2195 Time Limit: 1000MS Memory Limit: 65536K Description On a grid ma ...
- POJ 2195 Going Home 最小费用最大流 尼玛,心累
D - Going Home Time Limit:1000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I64u Subm ...
- poj 2195 Going Home(最小费用最大流)
题目:http://poj.org/problem?id=2195 有若干个人和若干个房子在一个给定网格中,每人走一个都要一定花费,每个房子只能容纳一人,现要求让所有人进入房子,且总花费最小. 构造一 ...
- poj 2351 Farm Tour (最小费用最大流)
Farm Tour Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 17230 Accepted: 6647 Descri ...
- POJ 2157 Evacuation Plan [最小费用最大流][消圈算法]
---恢复内容开始--- 题意略. 这题在poj直接求最小费用会超时,但是题意也没说要求最优解. 根据线圈定理,如果一个跑完最费用流的残余网络中存在负权环,那么顺着这个负权环跑流量为1那么会得到更小的 ...
- poj 2135 Farm Tour 最小费用最大流建图跑最短路
题目链接 题意:无向图有N(N <= 1000)个节点,M(M <= 10000)条边:从节点1走到节点N再从N走回来,图中不能走同一条边,且图中可能出现重边,问最短距离之和为多少? 思路 ...
- POJ 3680: Intervals【最小费用最大流】
题目大意:你有N个开区间,每个区间有个重量wi,你要选择一些区间,使得满足:每个点被不超过K个区间覆盖的前提下,重量最大 思路:感觉是很好想的费用流,把每个区间首尾相连,费用为该区间的重量的相反数(由 ...
- POJ 2135 Farm Tour [最小费用最大流]
题意: 有n个点和m条边,让你从1出发到n再从n回到1,不要求所有点都要经过,但是每条边只能走一次.边是无向边. 问最短的行走距离多少. 一开始看这题还没搞费用流,后来搞了搞再回来看,想了想建图不是很 ...
- [poj] 1235 Farm Tour || 最小费用最大流
原题 费用流板子题. 费用流与最大流的区别就是把bfs改为spfa,dfs时把按deep搜索改成按最短路搜索即可 #include<cstdio> #include<queue> ...
- POJ 2516 Minimum Cost [最小费用最大流]
题意略: 思路: 这题比较坑的地方是把每种货物单独建图分开算就ok了. #include<stdio.h> #include<queue> #define MAXN 500 # ...
随机推荐
- Spring boot jar 后台运行
start(){ now=`date "+%Y%m%d%H%M%S"` exec java -Xms256m -Xmx512m -jar /alidata/server/webap ...
- java学习笔记-继承中super关键字
背景: 在java继承的概念中我们得知,被声明为私有的类成员对所属的类来说仍然是私有的.类之外的任何代码都不能访问,包括子类. super关键字的两种用法: 1.用于调用超类的构造函数: 2.用于访问 ...
- 浅谈C#中的泛型
1.什么是泛型? 泛型是程序设计语言的一种特性.允许程序员在强类型程序设计语言中编写 代码时定义一些可变部分,那些部分在使用前必须作出指明.各种程序设计语言和其编译器.运行环境对泛型的支持均不一样.将 ...
- 创建采购订单批到程序用的BAPI
CALL FUNCTION 'BAPI_PO_CREATE1' EXPORTING poheader = poheader poheaderx = poheaderx * POADDRVENDOR = ...
- 【Demo 0005】Android 资源
本章学习要点: 1. 了解Android中资源用途: 2. 掌握资源使用通用规则: 3. 掌握具体资源使用方法; 一.Android资源 a ...
- hdu 4057 AC自己主动机+状态压缩dp
http://acm.hdu.edu.cn/showproblem.php?pid=4057 Problem Description Dr. X is a biologist, who likes r ...
- DotNetBar.Bar控制Y顺序控制方向
DotNetBar.Bar控件Y方向上的顺序控制 老帅 控件DevComponents.DotNetBar.Bar是能够有多种用途的.能够作为容器,也能够作为工具条,不管做什么,在Y方向上 ...
- Swift - 计算次方(2的N次方,2的随机次方)
1,使用<<计算2的N次方 1 2 var value = 1<<4 //2的4次方 var value = 1<<Int(arc4random_uniform( ...
- SAP自带的创建报表工具
SAP自带的工具有quickview和query两个主要的工具,当然还有其他的 quickview和query的区别主要是query支持系统之间的传输,quickview只能是用户的客户端创建使用,不 ...
- MS Project 2007 工期、工时、资源、固定单位、固定工期、固定工时
0. 基本概念 工期:指完成每项项目任务所经历的实际时间,及开始日期和结束时期之差.Project中,工期的默认单位是天. 工时:指将任务分配给资源后,每个资源执行任务的工作时间.Project中,工 ...