POJ_3068_Shortest_pair_of_paths_(最小费用流)
描述
http://poj.org/problem?id=3068
危险品:N个仓库由M条有向边连接,每条边都有一定费用。将两种危险品从0运到N-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。求最小费用.
(好吧直接抄来的0.0)
| Time Limit: 1000MS | Memory Limit: 65536K | |
| Total Submissions: 1220 | Accepted: 493 |
Description
There are N depots (vertices) where chemicals can be stored. There
are M individual shipping methods (edges) connecting pairs of depots.
Each individual shipping method has a cost. In the usual problem, the
company would need to find a way to route a single shipment from the
first depot (0) to the last (N - 1). That's easy. The problem they have
seems harder. They have to ship two chemicals from the first depot (0)
to the last (N - 1). The chemicals are dangerous and cannot safely be
placed together. The regulations say the company cannot use the same
shipping method for both chemicals. Further, the company cannot place
the two chemicals in same depot (for any length of time) without special
storage handling --- available only at the first and last depots. To
begin, they need to know if it's possible to ship both chemicals under
these constraints. Next, they need to find the least cost of shipping
both chemicals from first depot to the last depot. In brief, they need
two completely separate paths (from the first depot to the last) where
the overall cost of both is minimal.
Your program must simply determine the minimum cost or, if it's not
possible, conclusively state that the shipment cannot be made.
Input
input will consist of multiple cases. The first line of each input will
contain N and M where N is the number of depots and M is the number of
individual shipping methods. You may assume that N is less than 64 and
that M is less than 10000. The next M lines will contain three values,
i, j, and v. Each line corresponds a single, unique shipping method. The
values i and j are the indices of two depots, and v is the cost of
getting from i to j. Note that these shipping methods are directed. If
something can be shipped from i to j with cost 10, that says nothing
about shipping from j to i. Also, there may be more than one way to ship
between any pair of depots, and that may be important here.
A line containing two zeroes signals the end of data and should not be processed.
Output
Sample Input
2 1
0 1 20
2 3
0 1 20
0 1 20
1 0 10
4 6
0 1 22
1 3 11
0 2 14
2 3 26
0 3 43
0 3 58
0 0
Sample Output
Instance #1: Not possible
Instance #2: 40
Instance #3: 73
Source
分析
每个边的容量都是1,增加一个源点与汇点,与他们相连的边容量是2,费用是0.然后跑最小费用流即可.
注意:
1.加爆了什么的...好吧只有我才会犯这种智障错(撞墙).
ps.人生第一道最小费用流的题.还有两个月就NOI了,感觉这节奏不死真难.
#include<cstdio>
#include<cstring>
#include<vector>
#include<queue>
#include<algorithm>
#define rep(i,n) for(int i=0;i<(n);i++)
#define for1(i,a,n) for(int i=(a);i<=(n);i++)
#define read(a) a=getnum()
#define CC(i,a) memset(i,a,sizeof(i))
using namespace std; const int maxn=+,INF=<<;
int n,m;
bool vis[maxn];
int dis[maxn],prevv[maxn],preve[maxn];
struct edge
{
int to,cap,cost,rev;
edge(){}
edge(int a,int b,int c,int d):to(a),cap(b),cost(c),rev(d) {}
};
vector <edge> g[maxn]; inline int getnum()
{
int r=,k=; char c;
for(c=getchar();c<''||c>'';c=getchar()) if(c=='-') k=-;
for(;c>=''&&c<='';c=getchar()) r=r*+c-'';
return k*r;
} void add_edge(int from,int to,int cap,int cost)
{
g[from].push_back(edge(to,cap,cost,g[to].size()));
g[to].push_back(edge(from,,-cost,g[from].size()-));
} void Spfa(int s)
{
for1(i,,n+) dis[i]=INF;
dis[s]=;
CC(vis,);
queue <int> q;
q.push(s);
vis[s]=true;
while(!q.empty())
{
int t=q.front(); q.pop();
vis[t]=false;
rep(i,g[t].size())
{
edge e=g[t][i];
if(e.cap>&&dis[e.to]-e.cost>dis[t])
{
dis[e.to]=dis[t]+e.cost;
prevv[e.to]=t;
preve[e.to]=i;
if(!vis[e.to])
{
vis[e.to]=true;
q.push(e.to);
}
}
}
}
} int min_cost_flow(int s,int t,int f)
{
int res=;
while(f>)
{
Spfa(s);
if(dis[t]==INF) return -;
int d=f;
for(int v=t;v!=s;v=prevv[v])
{
d=min(d,g[prevv[v]][preve[v]].cap);
}
f-=d;
res+=d*dis[t];
for(int v=t;v!=s;v=prevv[v])
{
edge &e=g[prevv[v]][preve[v]];
e.cap-=d;
g[v][e.rev].cap+=d;
}
}
return res;
} int main()
{
#ifndef ONLINE_JUDGE
freopen("short.in","r",stdin);
freopen("short.out","w",stdout);
#endif
int cnt=;
while(scanf("%d%d",&n,&m)==&&(n!=||m!=))
{
for1(i,,m)
{
int from,to,cost;
read(from); read(to); read(cost);
from++; to++;
add_edge(from,to,,cost);
}
add_edge(,,,);
add_edge(n,n+,,);
printf("Instance #%d: ",++cnt);
int ans=min_cost_flow(,n+,);
if(ans==-)
{
printf("Not possible\n");
}
else
{
printf("%d\n",ans);
}
for1(i,,n+) g[i].clear();
}
#ifndef ONLINE_JUDGE
fclose(stdin);
fclose(stdout);
system("short.out");
#endif
return ;
}
POJ_3068_Shortest_pair_of_paths_(最小费用流)的更多相关文章
- POJ2195 最小费用流
题目:http://poj.org/problem?id=2195 处理出每个人到每个门的曼哈顿距离,分别建立容量为1费用为曼哈顿距离的边,在源点和每个人人之间建立容量为1费用为0的边,在门和汇点之间 ...
- HDU 4067 hdoj 4067 Random Maze 最小费用流
给出n个点,m条边,入口s和出口t,对于每条边有两个值a,b,如果保留这条边需要花费:否则,移除这条边需要花费b. 题目要求用最小费用构造一个有向图满足以下条件: 1.只有一个入口和出口 2.所有路都 ...
- POJ 2516:Minimum Cost(最小费用流)
https://vjudge.net/problem/11079/origin 题意:有N个商店和M个供应商和K种物品,每个商店每种物品有一个需求数,每个供应商每种物品有一个供应量,供应商到商店之间的 ...
- POJ-2175 Evacuation Plan 最小费用流、负环判定
题意:给定一个最小费用流的模型,根据给定的数据判定是否为最优解,如果不为最优解则给出一个比给定更优的解即可.不需要得出最优解. 解法:由给定的数据能够得出一个残图,且这个图满足了最大流的性质,判定一个 ...
- Going Home (hdu 1533 最小费用流)
集训的图论都快结束了,我才看懂了最小费用流,惭愧啊. = = 但是今天机械键盘到了,有弄好了自行车,好高兴\(^o^)/~ 其实也不是看懂,就会套个模板而已.... 这题最重要的就是一个: 多组输入一 ...
- POJ 2195 Going Home 最小费用流 裸题
给出一个n*m的图,其中m是人,H是房子,.是空地,满足人的个数等于房子数. 现在让每个人都选择一个房子住,每个人只能住一间,每一间只能住一个人. 每个人可以向4个方向移动,每移动一步需要1$,问所有 ...
- [haoi2010]订货 最小费用流
这道题oj上的标签是动态规划,但我想不出来动态规划怎么搞,空间不爆,时间也要爆的: 好的,不扯淡,此题正常做法是最小费用流: 这道题我写了两遍,为什么呢?原因是第一次写的时候,不会写费用流,又恰好没带 ...
- FZU2143Board Game(最小费用流)
题目大意是说有一个B矩阵,现在A是一个空矩阵(每个元素都为0),每次操作可以将A矩阵相邻的两个元素同时+1,但是有个要求就是A矩阵的每个元素都不可以超过K,求 这个的最小值 解题思路是这样的,新建起点 ...
- POJ 2516 Minimum Cost 最小费用流
题目: 给出n*kk的矩阵,格子a[i][k]表示第i个客户需要第k种货物a[i][k]单位. 给出m*kk的矩阵,格子b[j][k]表示第j个供应商可以提供第k种货物b[j][k]单位. 再给出k个 ...
随机推荐
- JS中的replace方法以及与正则表达式的结合应用
replace方法的语法是:stringobj.replace(rgexp, replacetext) 其中stringobj是字符串(string),reexp可以是正则表达式对象(regexp)也 ...
- Servlet单实例多线程模式
http://kakajw.iteye.com/blog/920839 前言:Servlet/JSP技术和ASP.PHP等相比,由于其多线程运行而具有很高的执行效率.由于Servlet/JSP默认是以 ...
- jdk在windows中的配置
1.下载jdk(java developer kit),其内部包含jre(java runtime environment): 安装解压缩到一盘内,如:G:\Program Files\Java: 2 ...
- 二、 What's Maven,How to learning?
1. 哈哈,什么是Maevn, ←_←|| ?我怎么知道,来看看官方解释, Apache Maven is a software project management and comprehensio ...
- xcode插件安装完之后无法使用问题解决
1.打开xcode插件所在的目录: 例如: ~/wangdi/library/Application Support/Developer/Shared/Xcode/Plug-ins /Users/su ...
- boost库----enable_shared_from_this类的作用和实现原理
使用boost库时,经常会看到如下的类 class A:public enable_share_from_this<A> 在什么情况下要使类A继承enable_share_from_thi ...
- c++ 中的8种智能指针[转]
一.简介 由于 C++ 语言没有自动内存回收机制,程序员每次 new 出来的内存都要手动 delete.程序员忘记 delete,流程太复杂,最终导致没有 delete,异常导致程序过早退出,没有执行 ...
- (redis缓存更新策略)postgres 9.4.1 && redis 3.7.0 && redis_fdw_REL9_4_STABLE
首先下载redis_fdw,这里要注意下载的版本.(https://github.com/pg-redis-fdw/redis_fdw) 一开始,我下载了REL9_4_STABLE_pre2.8版本, ...
- ubuntu ssh安装
参考 http://www.linuxidc.com/Linux/2010-02/24349.htm 文章很不错!! ssh 登录名@ip地址 , 如果提示验证key can't be esta ...
- sed工具使用
sed命令使用形式 1.sed命令从管道中读取数据处理 command | sed ' edit command' 通过管道把一个命令的标准输出读入到sed的标准输入,sed就起到了过滤作用 2.se ...