UVA-10806 Dijkstra, Dijkstra. (最小费用流,网络流建模)
题目大意:给一张带权简单图,找出一条经过起点s和终点t的最小回路。
题目分析:建立网络,以s为源点,t为汇点,另每条边的容量为1,单位费用为边权值。求最小费用流,增广两次后的最小费用便是答案。
代码如下:
# include<iostream>
# include<cstdio>
# include<cmath>
# include<string>
# include<vector>
# include<list>
# include<set>
# include<map>
# include<queue>
# include<cstring>
# include<algorithm>
using namespace std; # define LL long long
# define REP(i,s,n) for(int i=s;i<n;++i)
# define CL(a,b) memset(a,b,sizeof(a))
# define CLL(a,b,n) fill(a,a+n,b) const double inf=1e30;
const int INF=1<<30;
const int N=105; struct Edge
{
int fr,to,cap,flow,cost;
Edge(int _fr,int _to,int _cap,int _flow,int _cost):fr(_fr),to(_to),cap(_cap),flow(_flow),cost(_cost){}
};
vector<Edge>edges;
vector<int>G[N];
int p[N],a[N],d[N],inq[N]; void init(int n)
{
edges.clear();
REP(i,0,n) G[i].clear();
} void addEdge(int u,int v,int cost)
{
edges.push_back(Edge(u,v,1,0,cost));
edges.push_back(Edge(v,u,0,0,-cost));
int m=edges.size();
G[u].push_back(m-2);
G[v].push_back(m-1);
} bool BellmanFord(int s,int t,int &flow,int &cost)
{
CL(inq,0);
CLL(d,INF,t+1);
d[s]=0,inq[s]=1,p[s]=0,a[s]=INF; queue<int>q;
q.push(s);
while(!q.empty()){
int u=q.front();
q.pop();
inq[u]=0;
REP(i,0,G[u].size()){
Edge &e=edges[G[u][i]];
if(d[e.to]>d[u]+e.cost&&e.cap>e.flow){
d[e.to]=d[u]+e.cost;
p[e.to]=G[u][i];
a[e.to]=min(a[u],e.cap-e.flow);
if(!inq[e.to]){
inq[e.to]=1;
q.push(e.to);
}
}
}
}
if(d[t]==INF) return false;
flow+=a[t];
cost+=a[t]*d[t];
for(int x=t;x!=s;x=edges[p[x]].fr){
edges[p[x]].flow+=a[t];
edges[p[x]^1].flow-=a[t];
}
return true;
} void solve(int s,int t)
{
int flow=0,cost=0;
if(!BellmanFord(s,t,flow,cost)) printf("Back to jail\n");
else{
if(BellmanFord(s,t,flow,cost)) printf("%d\n",cost);
else printf("Back to jail\n");
}
} int main()
{
int s,t,n,m,a,b,c;
while(scanf("%d",&n)&&n)
{
s=0,t=n-1;
init(n);
scanf("%d",&m);
while(m--)
{
scanf("%d%d%d",&a,&b,&c);
addEdge(a-1,b-1,c);
addEdge(b-1,a-1,c);
}
solve(s,t);
}
return 0;
}
UVA-10806 Dijkstra, Dijkstra. (最小费用流,网络流建模)的更多相关文章
- uva 10806 Dijkstra, Dijkstra. (最小费最大流)
		uva 10806 Dijkstra, Dijkstra. 题目大意:你和你的伙伴想要越狱.你的伙伴先去探路,等你的伙伴到火车站后,他会打电话给你(电话是藏在蛋糕里带进来的),然后你就能够跑去火车站了 ... 
- UVa 10806 Dijkstra,Dijkstra(最小费用最大流)
		裸的费用流.往返就相当于从起点走两条路到终点. 按题意建图,将距离设为费用,流量设为1.然后增加2个点,一个连向节点1,流量=2,费用=0;结点n连一条同样的弧,然后求解最小费用最大流.当且仅当最大流 ... 
- UVA 11082 矩阵解压(网络流建模)
		矩阵解压 紫书P374 建模真的是挺难的,如果直接给我这题,我是想不到用网络流的,所以还应多做网路流建模,学会如何转化成网络流 还有,现在用的EK算法是比较慢的,还应去看看Dnic和ISAP,并且理解 ... 
- 培训补坑(day4:网络流建模与二分图匹配)
		补坑时间到QAQ 好吧今天讲的是网络流建模与二分图匹配... day3的网络流建模好像说的差不多了.(囧) 那就接着补点吧.. 既然昨天讲了建图思想,那今天就讲讲网络流最重要的技巧:拆点. 拆点,顾名 ... 
- UVA 10806 Dijkstra, Dijkstra.
		题意: 从起点走到终点,然后从终点走到起点,其中不能同时走过相同的一条边,问你最小路径长度.先输入终点n,起点为1,接下来输入m,代表有m条边.每条边由起点,终点,长度组成. 分析: 求最小长度,还限 ... 
- UVA 10806 Dijkstra, Dijkstra.(费用流)
		n个点的无向带权图,求1->n的最短往返路径,不走重复边. 这里涉及到一个知识点:求无向图上s->t的最短路,其实就是费用流. 而求1->n最短往返路径呢?增加源点s,由s到1加弧, ... 
- UVa10806 Dijkstra,Dijkstra-费用网络流
		Problem, in short Given a weighed, undirected graph, find the shortest path from S to T and back wit ... 
- UVa 11082 (网络流建模) Matrix Decompressing
		网络流不难写,难的建一个能解决问题的模型.. 即使我知道这是网络流专题的题目,也绝不会能想出这种解法,=_=|| 题意: 给出一个矩阵的 前i行和 以及 前i列和,然后找到一个满足要求的矩阵,而且每个 ... 
- 最短路模板(Dijkstra & Dijkstra算法+堆优化 & bellman_ford  & 单源最短路SPFA)
		关于几个的区别和联系:http://www.cnblogs.com/zswbky/p/5432353.html d.每组的第一行是三个整数T,S和D,表示有T条路,和草儿家相邻的城市的有S个(草儿家到 ... 
随机推荐
- Oracle表的维护(字段,重命名表名)
			案例:银行里建的开卡信息 字段 字段类型 Id Number name Varchar2(64) sex Char2() birth Date money Number(10,2) 创建银行卡表 cr ... 
- IIS中User-mode caching引起的Cache-Control不为public的问题
			在IIS的Output caching中如果启用了User-mode caching将引起Cache-Control为no-cache,从而造成页面不能被浏览器或代理服务器缓存. web.config ... 
- 使用 Visual Studio 将 ASP.NET Web 应用部署到 Azure
			原文地址:https://www.azure.cn/zh-cn/documentation/articles/web-sites-dotnet-get-started 配置新的 Web 项目 下一步是 ... 
- Qt 模拟鼠标点击(QApplication::sendEvent(ui->pushbutton, &event0);)
			QPoint pos(0,0);QMouseEvent event0(QEvent::MouseButtonPress, pos, Qt::LeftButton, Qt::LeftButton, Qt ... 
- 最长DNA重复序列长度,并输出该序列。 JAVA
			1: 最长DNA重复序列长度,并输出该序列. 例如 ATCGTAGATCG,它的最大长度为4,序列为 ATCG. package com.li.huawei; import java.util.S ... 
- PAT 1065 A+B and C[大数运算][溢出]
			1065 A+B and C (64bit)(20 分) Given three integers A, B and C in [−263,263], you are supposed t ... 
- windows下和linux下libcurl安装
			下载源代码,在winbuild里面有个说明文件: Building with Visual C++, prerequisites==================================== ... 
- JavaScript在页面中的引用方法
			现在前端开发越来越流行,框架也越来越多,像ExtJs.JQuery.Bootstrap等.虽然入行这么多年,但是感觉自己在前端方面还是存在基础不牢的地方,特别是CSS和JS.因此最近打算重新阅读这方面 ... 
- python openpyxl 封装Execl常用操作的方法
			封装Excel操作方法:先装openpyxl:pip install openpyxl==2.4.5(可以指定版本) 封装脚本:#encoding=utf-8 from openpyxl import ... 
- c++第二十三天
			p124~p126: 算数运算符 1.形如+ -(一元) * / % + -(二元)为算数运算符. 2.所有算数运算符都满足左结合律. 3.算数运算符的运算对象和求值结果都是右值. 4.在表达式求值之 ... 
