【uva1658 算法竞赛入门经典】海军上将【费用流】

时间:2021-10-06 15:00:01

题意

给出一个v(3<=v<=1000)个点e(3<=e<=10000)条边的有向加权图,求1-v的两条不相交(除了起点和终点外没有公共点)的路径,使得权和最小。

分析

费用流的一个经典用法就是限制没有公共边边,但是这个题有个不同,这个题限制的是没有公共点。因此,我们把每个点拆出一条边来。

把2到v-1的每个结点i拆成i和i‘两个结点,中间连一条容量为1,费用为0的边。对于原图中的每一条边(a,b),连一条弧(a',b),容量为1,费用为权值然后求1到v的流量为2的最小费用流即可。

 #include <cstdio>
#include <cstring>
#include <algorithm>
#include <iostream>
#include <queue> using namespace std;
const int maxn=+;
const int maxm=+;
const int INF=;
struct MCMF{
int head[maxn],Next[maxm],to[maxm],from[maxm],flow[maxm],cap[maxm],cost[maxm];
int inq[maxn],d[maxn],p[maxn],a[maxn];
int n,m,s,t,sz;
void init(int n){
this->n=n;
sz=-;
memset(head,-,sizeof(head));
}
void add_edge(int a,int b,int ca,int co){
++sz;
from[sz]=a;to[sz]=b;Next[sz]=head[a];head[a]=sz;
cap[sz]=ca;cost[sz]=co;flow[sz]=;
++sz;
from[sz]=b;to[sz]=a;Next[sz]=head[b];head[b]=sz;
cap[sz]=ca;cost[sz]=-co;flow[sz]=ca;
}
bool spfa(int s,int t,int &Flow ,long long &Cost){
for(int i=;i<=n;i++)d[i]=INF;
queue<int>Q;
memset(inq,,sizeof(inq));
d[s]=;inq[s]=;p[s]=-;a[s]=INF;
Q.push(s);
while(!Q.empty()){
int u=Q.front();Q.pop();
inq[u]=;
for(int i=head[u];i!=-;i=Next[i]){
int v=to[i];
if(cap[i]>flow[i]&&d[v]>d[u]+cost[i]){
d[v]=d[u]+cost[i];
p[v]=i;
a[v]=min(a[u],cap[i]-flow[i]);
if(!inq[v]){
inq[v]=;
Q.push(v);
}
}
}
}
if(d[t]==INF)return false;
Flow+=a[t];
Cost+=(long long)a[t]*(long long)d[t];
int u=t;
while(u!=s){
flow[p[u]]+=a[t];
flow[p[u]^]-=a[t];
u=from[p[u]];
}
return true;
}
long long Mincost(int s,int t){
int Flow=;
long long Cost=;
while(spfa(s,t,Flow,Cost));
return Cost;
}
}mcmf;
int n,m;
int main(){
while(scanf("%d%d",&n,&m)!=EOF){
int a,b,c;
mcmf.init(*n);
for(int i=;i<n;i++){
mcmf.add_edge(i,i+n,,);
}
mcmf.add_edge(,n+,,);
mcmf.add_edge(n,*n,,);
for(int i=;i<=m;i++){
scanf("%d%d%d",&a,&b,&c);
mcmf.add_edge(a+n,b,,c);
}
int ans=mcmf.Mincost(,*n);
cout<<ans<<endl;
}
return ;
}

【uva1658 算法竞赛入门经典】海军上将【费用流】的更多相关文章

  1. (Step1-500题)UVaOJ&plus;算法竞赛入门经典&plus;挑战编程&plus;USACO

    http://www.cnblogs.com/sxiszero/p/3618737.html 下面给出的题目共计560道,去掉重复的也有近500题,作为ACMer Training Step1,用1年 ...

  2. &lbrack;刷题&rsqb;算法竞赛入门经典 3-12&sol;UVa11809

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 题目:算法竞赛入门经典 3-4/UVa11809:Floating-Point Numbers 代码: //UVa11 ...

  3. &lbrack;刷题&rsqb;算法竞赛入门经典 3-10&sol;UVa1587 3-11&sol;UVa1588

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 题目:算法竞赛入门经典 3-10/UVa1587:Box 代码: //UVa1587 - Box #include&l ...

  4. &lbrack;刷题&rsqb;算法竞赛入门经典 3-7&sol;UVa1368 3-8&sol;UVa202 3-9&sol;UVa10340

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 都是<算法竞赛入门经典(第二版)>的题目,标题上没写(第二版) 题目:算法竞赛入门经典 3-7/UVa13 ...

  5. &lbrack;刷题&rsqb;算法竞赛入门经典 3-4&sol;UVa455 3-5&sol;UVa227 3-6&sol;UVa232

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO 题目:算法竞赛入门经典 3-4/UVa455:Periodic Strings 代码: //UVa455 #inclu ...

  6. &lbrack;刷题&rsqb;算法竞赛入门经典 3-1&sol;UVa1585 3-2&sol;UVa1586 3-3&sol;UVa1225

    书上具体所有题目:http://pan.baidu.com/s/1hssH0KO(我也是在网上找到的pdf,但不记得是从哪里搜刮到的了,就重新上传了一遍) PS:第一次写博客分享我的代码,不知道我对c ...

  7. 算法竞赛入门经典训练指南——UVA 11300 preading the Wealth

    A * regime is trying to redistribute wealth in a village. They have have decided to sit ever ...

  8. 算法竞赛入门经典&plus;挑战编程&plus;USACO

    下面给出的题目共计560道,去掉重复的也有近500题,作为ACMer Training Step1,用1年到1年半年时间完成.打牢基础,厚积薄发. 一.UVaOJ http://uva.onlinej ...

  9. 算法竞赛入门经典 LA 4329&lpar;树状数组)

    题意: 一排有着不同能力值的人比赛,规定裁判的序号只能在两人之间,而且技能值也只能在两人之间 问题: <算法竞赛入门经典-训练指南>的分析: 上代码: #include<iostre ...

随机推荐

  1. 【HTML5】video视频

    当前,video 元素支持三种视频格式: 格式 IE Firefox Opera Chrome Safari Ogg No 3.5+ 10.5+ 5.0+ No MPEG 4 9.0+ No No 5 ...

  2. 用PHP添加购物商品

    <?php session_start(); header ( "Content-type: text/html; charset=UTF-8" ); //设置文件编码格式 ...

  3. mysql和mysqli的区别

    看书.看视频的时候一直没有搞懂mysqli和mysql到底有什么区别.于是今晚“谷歌”一番,整理一下.需要的朋友可以参考下.   一: PHP-MySQL 是 PHP 操作 MySQL 数据库最原始的 ...

  4. WPF DataGrid 增加&quot&semi;更新&quot&semi;模板列&comma;根据行Row的选择而显示&quot&semi;更新&quot&semi;按钮

    SelectionMode="Single" <DataGridTemplateColumn Header=""> <DataGridTemp ...

  5. TDD

    初识TDD 首先说一下名词解释,TDD,英文名称Test-Driven Development,中文名称测试驱动开发,简单的断下句“测试/驱动/开发”,简单的理解一下,就是测试驱动着开发,大白话就是说 ...

  6. linux下编译php追加enable的方法

    如果我们运行php时发现缺少某个库,在windows环境下很简单,找到.dll 对应的库文件,然后拷贝到 extension 目录下,然后在php.ini 里 去掉 前面的分号或者 追加一行 exte ...

  7. ASP从HTML标签中提取中文

    Function delHtml(strHtml) '做了一个函数名叫delhtml Dim objRegExp, strOutput Set objRegExp = New Regexp ' 建立正 ...

  8. Project Euler 92&colon;Square digit chains C&plus;&plus;

    A number chain is created by continuously adding the square of the digits in a number to form a new ...

  9. Harbor删除镜像后且GC清理后,磁盘空间没有释放的问题

    1.原因 Harbor删除镜像后且GC清理后,磁盘空间没有释放.因为我们push大量相同标签的镜像,Docker 镜像由标签引用,并由唯一的摘要标识.这意味着如果myImage使用标记推送两个图像,在 ...

  10. js:苹果手机页面返回,数据不刷新问题

    $(function () {     var isPageHide = false;     window.addEventListener('pageshow', function () {    ...