跑出最短路图,然后把结点拆点跑最大流。

#include<cstdio>
#include<queue>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
#define M 100001
#define INF 2147483647
#define N 501
typedef long long ll;
namespace Net
{
int v[M<<1],next[M<<1],first[N<<1],en,cap[M<<1];
queue<int>q;
void AddEdge(int U,int V,int Cap)
{
v[en]=V; cap[en]=Cap; next[en]=first[U]; first[U]=en++;
v[en]=U; next[en]=first[V]; first[V]=en++;
}
int S,T,n;
int d[N<<1],cur[N<<1];
int bfs()
{
memset(d,-1,sizeof(int)*(n+1));
d[S]=0;
q.push(S);
while(!q.empty())
{
int U=q.front(); q.pop();
for(int i=first[U];i!=-1;i=next[i])
if(cap[i]&&d[v[i]]==-1)
{
d[v[i]]=d[U]+1;
q.push(v[i]);
}
}
return d[T]!=-1;
}
int dfs(int U,int a)
{
if(U==T||(!a))
return a;
int f,Flow=0;
for(int &i=cur[U];i!=-1;i=next[i])
if(d[v[i]]==d[U]+1&&(f=dfs(v[i],min(a,cap[i]))))
{
cap[i]-=f; cap[i^1]+=f;
Flow+=f; a-=f;
if(!a) break;
}
if(!Flow) d[U]=-1;
return Flow;
}
ll MaxFlow()
{
ll Flow=0;
int tmp;
while(bfs())
{
memcpy(cur,first,sizeof(int)*(n+1));
while(tmp=dfs(S,INF))
Flow+=(ll)tmp;
}
return Flow;
}
};
namespace SP
{
int n,m;
queue<int>q;
int v[M<<1],w[M<<1],next[M<<1],first[N],en;
void AddEdge(int U,int V,int W)
{
v[++en]=V;
w[en]=W;
next[en]=first[U];
first[U]=en;
}
ll d[N];
bool inq[N];
void spfa(int S)
{
for(int i=1;i<=n;++i)
d[i]=INF;
d[S]=0;
q.push(S);
inq[S]=1;
while(!q.empty())
{
int U=q.front();
for(int i=first[U];i;i=next[i])
if(d[U]+(ll)w[i]<d[v[i]])
{
d[v[i]]=d[U]+(ll)w[i];
if(!inq[v[i]])
{
inq[v[i]]=1;
q.push(v[i]);
}
}
q.pop(); inq[U]=0;
}
}
};
int Map(int x,bool op)
{
if(x==Net::S||x==Net::T)
return x;
return ((!op)?((x<<1)-2):((x<<1)-1));
}
int main()
{
int x,y,z;
scanf("%d%d",&SP::n,&SP::m);
for(int i=1;i<=SP::m;++i)
{
scanf("%d%d%d",&x,&y,&z);
SP::AddEdge(x,y,z);
SP::AddEdge(y,x,z);
}
SP::spfa(1);
Net::S=1;
Net::T=2*SP::n-2;
Net::n=2*SP::n-2;
memset(Net::first,-1,sizeof(int)*(Net::n+1));
for(int i=1;i<=SP::en;i+=2)
{
if(SP::d[SP::v[i+1]]+(ll)SP::w[i]==SP::d[SP::v[i]])
Net::AddEdge(Map(SP::v[i+1],1),Map(SP::v[i],0),INF);
if(SP::d[SP::v[i]]+(ll)SP::w[i]==SP::d[SP::v[i+1]])
Net::AddEdge(Map(SP::v[i],1),Map(SP::v[i+1],0),INF);
}
scanf("%d",&x);
for(int i=2;i<SP::n;++i)
{
scanf("%d",&x);
Net::AddEdge(Map(i,0),Map(i,1),x);
}
scanf("%d",&x);
cout<<Net::MaxFlow()<<endl;
return 0;
}

【最短路】【最大流】bzoj3931 [CQOI2015]网络吞吐量的更多相关文章

  1. bzoj千题计划136:bzoj3931: [CQOI2015]网络吞吐量

    http://www.lydsy.com/JudgeOnline/problem.php?id=3931 在最短路网络上跑最大流 #include<queue> #include<c ...

  2. bzoj3931: [CQOI2015]网络吞吐量(spfa+网络流)

    3931: [CQOI2015]网络吞吐量 题目:传送门 题解: 现在有点难受....跳了一个多钟...菜啊... 题意都把做法一起给了....最短路+网路流啊. 不想说话...记得开long lon ...

  3. bzoj3931: [CQOI2015]网络吞吐量

    将最短路图找出来,跑maxflow即可.有注意到数据范围.然后输出的时候%dWA了三次QAQ... #include<cstdio> #include<cstring> #in ...

  4. BZOJ3931 [CQOI2015]网络吞吐量(最大流)

    没啥好说的,有写过类似的,就是预处理出最短路上的边建容量网络. #include<cstdio> #include<cstring> #include<queue> ...

  5. [bzoj3931][CQOI2015]网络吞吐量——最短路+网络流

    题目 传送门 题解 第一次一遍就AC一道bzoj上的题,虽然是一道水题... 我们做一边最短路,求出每个点的dist,然后再做一次类似spfa的操作,求出每个点是否可以用于建图. 在新图上拆点跑一边d ...

  6. 【BZOJ3931】[CQOI2015]网络吞吐量 最大流

    [BZOJ3931][CQOI2015]网络吞吐量 Description 路由是指通过计算机网络把信息从源地址传输到目的地址的活动,也是计算机网络设计中的重点和难点.网络中实现路由转发的硬件设备称为 ...

  7. 【BZOJ-3931】网络吞吐量 最短路 + 最大流

    3931: [CQOI2015]网络吞吐量 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 1228  Solved: 524[Submit][Stat ...

  8. BZOJ 3931: [CQOI2015]网络吞吐量( 最短路 + 最大流 )

    最短路 + 最大流 , 没什么好说的... 因为long long WA 了两次.... ------------------------------------------------------- ...

  9. BZOJ 3931: [CQOI2015]网络吞吐量 最大流

    3931: [CQOI2015]网络吞吐量 Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/p ...

随机推荐

  1. CentOS系统缺少库文件解决办法

    By francis_hao    May 31,2017   程序在编译时出现缺少库文件的提示,如下: as: error while loading shared libraries: libz. ...

  2. 如何把阿里云的服务器配置为mac的共享文件夹(亲测有效)

    写在开头的就是,我只能百分之九十确定这个是真的有效....毕竟试了太多的方法,最后莫名其妙的就好了.. - -# 基础的步骤就不说了,网上一搜一大把,大家可能follow了所有的步骤以后发现还是连接不 ...

  3. [codechef MEXDIV]Mex division

    题目链接:https://vjudge.net/contest/171650#problem/I 直接用set+dp水过去了... /* 设dp[i]表示前i个做划分满足条件的方案数 有一个显然的转移 ...

  4. net.sf.json与fastjson两种jar包的使用

    首先说清楚:这两种方式是进行json解析的两种不同的方式而已,哪一种都可以. 一.引入net.sf.json包 首先用net.sf.json包,当然你要导入很多包来支持commons-beanutil ...

  5. 用filters定制化spring的包扫描

    Fiter的信息如下: Filter的类型有:annotation(这是spring默认的),assignable,aspectj, regex,custom 首先看一下我这个demo的目录结构: 上 ...

  6. oracle的rownum使用

    对于rownum来说它是Oracle系统顺序分配为从查询返回的行的编号,返回的第一行分配的是1,第二行是2,依此类推,这个伪字段可以用于限制查询返回的总行数,且rownum不能以任何表的名称作为前缀. ...

  7. windows10-seaslog安装笔记

    1.seasLog在windows下的安装 首先,要下载seasLog的dll文件,下载地址:http://pecl.php.net/package/SeasLog  选择对应你的系统和php版本的d ...

  8. spring boot修改内置容器tomcat的服务端口

    方式一 在spring boot的web 工程中,可以使用内置的web container.有时需要修改服务端口,可以通过配置类和@Configuration注解来完成. // MyConfigura ...

  9. MyBatis系列四 之 智能标签进行查询语句的拼接

    MyBatis系列四 之 智能标签进行查询语句的拼接 使用Foreach进行多条件查询 1.1 foreach使用数组进行多条件查询 在MyBatis的映射文件中进行如下配置 <!--根据数组进 ...

  10. TensorFlow 官方文档中文版【转】

    转自:http://wiki.jikexueyuan.com/project/tensorflow-zh/ TensorFlow 官方文档中文版 你正在阅读的项目可能会比 Android 系统更加深远 ...