重新切一遍最小费用最大流~~~

这到题目的数据范围有问题,尽量开大就好了~~

#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最小费用最大流的更多相关文章

  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 2195 Going Home(最小费用最大流)

    题目:http://poj.org/problem?id=2195 有若干个人和若干个房子在一个给定网格中,每人走一个都要一定花费,每个房子只能容纳一人,现要求让所有人进入房子,且总花费最小. 构造一 ...

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

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

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

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

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

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

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

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

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

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

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

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

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

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

随机推荐

  1. Delphi中MethodAddress汇编代码的解析

    class function TObject.MethodAddress(const Name: ShortString): Pointer;asm        { ->    EAX     ...

  2. 基于visual Studio2013解决面试题之0502字符串左移

     题目

  3. c#后台弹出提示

    Page.ClientScript.RegisterClientScriptBlock(typeof(string), "", @"<script>alert ...

  4. C++学习之路—多态性与虚函数(二)纯虚函数与抽象类

    (根据<C++程序设计>(谭浩强)整理,整理者:华科小涛,@http://www.cnblogs.com/hust-ghtao转载请注明) 1    纯虚函数 在前面的博客中已经提到:有时 ...

  5. MSSQL - SQL Server2008附加数据库失败 错误号:5120

    附加数据库时,显示错误,错误信息为 一种解决方法为,设置mdf文件所在文件夹的权限(有些资料说只设置mdf文件的权限就好,但我试了不管用),在文件夹上右击——属性——安全,如图所示: 选择组或用户名中 ...

  6. LLBL Gen Pro 5.0

    LLBL Gen Pro 5.0 企业应用开发入门 Solutions Design 公司于2016年5月发布了LLBL Gen Pro 5.0,这个新版本的发布出乎于我的意料.我的猜想是从4.2升级 ...

  7. CentOS6.4 安装Mysql

    虽说,新版的数据包可能会带上一些新特性,但是数据库对我而言,还是稳定版优先.因为新特性不一定我会用到.. 下载安装: yum list | grep mysql 因为是准备搞开发用的,所以只要安装my ...

  8. sed正则表达式

    sed的正则匹配如何实现非贪婪? sed的正则用的是BREs/EREs,不支持非贪婪模式.当然有一些方法可以实现非贪婪,比如: $ echo abcOabcdOabc | sed 's/.*O//' ...

  9. OPPO通过AWS节约大量成本提供海外服务

    关于OPPO OPPO最早被人熟知是在以MP3和MP4为代表的影音市场.转型进入手机市场后,OPPO获得了更大发展机遇,近几年更是成为发展速度最快的国产品牌之中的一个.早在2010年前就開始了海外市场 ...

  10. SetFocus、SetCapture和SetActiveView的区别

    1. SetActiveView是MFC框架内的一个函数, 而不是SDK中的函数, 也就是说SDK中没有ActiveView这个概念, 只有在MFC中才有2. SetFocus是SDK中的函数(当然M ...