Problem, in short Given a weighed, undirected graph, find the shortest path from S to T and back without using the same edge twice.

很基础的费用网络流

 #include<iostream>
 #include<cstdio>
 #include<cstring>
 #include<queue>
 #include<vector>
 #define LL long long
 #define maxn 1024
 using namespace std;
 <<;
 struct Edge{
     int from,to,dist,flow,cap;
 };
 int n,m,d[maxn],a[maxn],inq[maxn],p[maxn];
 vector<Edge> edges;
 vector<int> G[maxn];
 void addEdge(int from,int to,int dist){
     edges.push_back((Edge){,});
     edges.push_back((Edge){to,,});
     int m=edges.size();
     G[);
     G[to].push_back(m-);
 }
 void connect(){
     edges.push_back((Edge){,n+,,,});
     edges.push_back((Edge){n+,,,,});
     int m=edges.size();
     G[].push_back(m-);
     G[n+].push_back(m-);
     edges.push_back((Edge){n+,,,,});
     edges.push_back((Edge){,n+,,,});
     m+=;
     G[n+].push_back(m-);
     G[].push_back(m-);
     edges.push_back((Edge){n,n+,,,});
     edges.push_back((Edge){n+,n,,,});
     m+=;
     G[n].push_back(m-);
     G[n+].push_back(m-);
     edges.push_back((Edge){n+,n,,,});
     edges.push_back((Edge){n,n+,,,});
     m+=;
     G[n+].push_back(m-);
     G[n].push_back(m-);
 }
 bool BF(int s,int t,int &flow,int &cost){
     memset(inq,,sizeof(inq));
     ;i<=n+;i++) d[i]=inf;
     inq[s]=;d[s]=;a[s]=inf;
     queue<int> Q;
     Q.push(s);
     while(!Q.empty()){
         int u=Q.front();Q.pop();
         inq[u]=;
         ;i<G[u].size();i++){
             Edge &e=edges[G[u][i]];
             if(e.cap>e.flow&&d[e.to]>d[u]+e.dist){
                 d[e.to]=d[u]+e.dist;
                 a[e.to]=min(a[u],e.cap-e.flow);
                 p[e.to]=G[u][i];
                 if(!inq[e.to]){
                     inq[e.to]=;
                     Q.push(e.to);
                 }
             }
         }
     }
     if(d[t]>=inf) return false;
     flow+=a[t];
     cost+=a[t]*d[t];
     int u=t;
     for(;u!=s;u=edges[p[u]].from){
         edges[p[u]].flow+=a[t];
         edges[p[u]^].flow-=a[t];
     }
     return true;
 }
 void init(){
     edges.clear();
     ;i<=n+;i++) G[i].clear();
 }
 int main()
 {
     while(scanf("%d",&n)&&n){
         scanf("%d",&m);
         init();
         int x,y,d;
         ;i<=m;i++){
             scanf("%d%d%d",&x,&y,&d);
             addEdge(x,y,d);addEdge(y,x,d);
         }
         connect();
         ,cost=;
         ,n+,flow,cost));
         ){
             puts("Back to jail");
         }else{
             printf("%d\n",cost);
         }
     }
     ;
 }

UVa10806 Dijkstra,Dijkstra-费用网络流的更多相关文章

  1. UVa 10806 Dijkstra,Dijkstra(最小费用最大流)

    裸的费用流.往返就相当于从起点走两条路到终点. 按题意建图,将距离设为费用,流量设为1.然后增加2个点,一个连向节点1,流量=2,费用=0;结点n连一条同样的弧,然后求解最小费用最大流.当且仅当最大流 ...

  2. HDU 6611 K Subsequence(Dijkstra优化费用流 模板)题解

    题意: 有\(n\)个数\(a_1\cdots a_n\),现要你给出\(k\)个不相交的非降子序列,使得和最大. 思路: 费用流建图,每个点拆点,费用为\(-a[i]\),然后和源点连边,和后面非降 ...

  3. uva 10806 Dijkstra, Dijkstra. (最小费最大流)

    uva 10806 Dijkstra, Dijkstra. 题目大意:你和你的伙伴想要越狱.你的伙伴先去探路,等你的伙伴到火车站后,他会打电话给你(电话是藏在蛋糕里带进来的),然后你就能够跑去火车站了 ...

  4. 【最小费用最大流模板】【Uva10806+Spring Team PK】Dijkstra, Dijkstra,

    题意:从1到n 再从n到1 不经过重复的边 ,(如果是点就是旅行商问题了),问最短路 建立一个超级源S S到1连一条费用为0,容量为2的边,求费用流即可 如果流<2 那么hehe 否则    输 ...

  5. UVA-10806 Dijkstra, Dijkstra. (最小费用流,网络流建模)

    题目大意:给一张带权简单图,找出一条经过起点s和终点t的最小回路. 题目分析:建立网络,以s为源点,t为汇点,另每条边的容量为1,单位费用为边权值.求最小费用流,增广两次后的最小费用便是答案. 代码如 ...

  6. dijkstra 最小费用最大流

    前言:众所周知:spfa他死了 滑稽 dijkstra同样为最短路算法,为什么不能跑费用流qwq 好像是因为有负权边的缘故 但是如果我们如果使用某种玄学的将边权都拉回到正数的话 就可以跑了dijkst ...

  7. UVA 10806 Dijkstra, Dijkstra.(费用流)

    n个点的无向带权图,求1->n的最短往返路径,不走重复边. 这里涉及到一个知识点:求无向图上s->t的最短路,其实就是费用流. 而求1->n最短往返路径呢?增加源点s,由s到1加弧, ...

  8. 最短路模板(Dijkstra & Dijkstra算法+堆优化 & bellman_ford & 单源最短路SPFA)

    关于几个的区别和联系:http://www.cnblogs.com/zswbky/p/5432353.html d.每组的第一行是三个整数T,S和D,表示有T条路,和草儿家相邻的城市的有S个(草儿家到 ...

  9. UVA 10806 Dijkstra, Dijkstra.

    题意: 从起点走到终点,然后从终点走到起点,其中不能同时走过相同的一条边,问你最小路径长度.先输入终点n,起点为1,接下来输入m,代表有m条边.每条边由起点,终点,长度组成. 分析: 求最小长度,还限 ...

随机推荐

  1. Hadoop数据类型介绍

    我们知道hadoop是由Java 编程写的.因此我们使用Java开发环境来操作HDFS,编写mapreduce也是很自然的事情.但是这里面hadoop却对Java数据类型进行了包装,那么hadoop的 ...

  2. Android Studio 1.5错误

    Error:Unable to start the daemon process: could not reserve enough space for object heap. Please ass ...

  3. Swift的文档注释

    官方文档地址:https://developer.apple.com/library/mac/documentation/Xcode/Reference/xcode_markup_formatting ...

  4. 转 纯CSS设置Checkbox复选框控件的样式

    Checkbox复选框是一个可能每一个网站都在使用的HTML元素,但大多数人并不给它们设置样式,所以在绝大多数网站它们看起来是一样的.为什么不把你的网站中的Checkbox设置一个与众不同的样式,甚至 ...

  5. android 检测网络是否连接,或者GPS是否可用

    很多android程序在打开时,检测网络是否连接,或者GPS是否可用: 1.网络是否连接(包括Wifi和移动网络) // 是否有可用网络 private boolean isNetworkConnec ...

  6. MEDIA-SYSSERVICES媒体播放

    1 简单的音乐播放器 1.1 问题 本案例结合之前所学的网络和数据解析等知识完成一个网络音乐播放器,如图-1所示: 图-1 1.2 方案 首先创建一个SingleViewApplication应用,在 ...

  7. 解决ubuntu下安装phpmyadmin访问不了的问题

    在/etc/apache2/sites-available下有个文件 000-default.conf 文件为只读,需要sudo 命令修改,  把DocumentRoot /var/www/html ...

  8. Oracle学习系列6

    Oracle学习系列6 ************************************************************************************ 删除约 ...

  9. HEX格式数据转换成十六进制字符串

    /** * Hex格式数据转换成十六进制字符串 * @param src */ public void bytesToHexString(byte[] by){ StringBuilder strin ...

  10. 怎样用JS获取ASP.NET服务器控件的客户端ID

    虽然简单,不过曾经困扰多时,还是记录一下吧. 来源:http://mou518.blog.163.com/blog/static/1756052222010111434428828/ 因为经常服务器控 ...