BZOJ 2324: [ZJOI2011]营救皮卡丘(带上下限的最小费用最大流)
这道题么= =还是有些恶心的,第一次写带上下界的网络流,整个人都萌萌哒~~~
首先先预处理得最短路后
直接用费用流做就行了。
第一次写,还是挺好写的= =
CODE:
#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<queue>
using namespace std;
#define maxn 310
#define maxm 100000
struct edges{
int to,next,cap,dist;
}edge[maxm];
int next[maxn],l;
void addedge(int x,int y,int z,int d){
l++;
edge[l*2]=(edges){y,next[x],z,d};next[x]=l*2;
edge[l*2+1]=(edges){x,next[y],0,-d};next[y]=l*2+1;
}
int inf;
int dist[maxn],w[maxn],s,t,cnt;
bool b[maxn];
queue<int> q;
bool spfa() {
for (int i=1;i<=cnt;i++) dist[i]=inf;
dist[s]=0;
q.push(s);
while (!q.empty()) {
int u=q.front();q.pop();
b[u]=0;
for (int i=next[u];i;i=edge[i].next)
if (edge[i].cap&&edge[i].dist+dist[u]<dist[edge[i].to]) {
dist[edge[i].to]=dist[u]+edge[i].dist;
w[edge[i].to]=i;
if (!b[edge[i].to]) {
b[edge[i].to]=1;
q.push(edge[i].to);
}
}
}
return dist[t]!=inf;
}
int ans;
int mcmf(int ss,int tt){
s=ss,t=tt;
while (spfa()) {
int x=t,flow=inf;
while (x!=s) {
flow=min(flow,edge[w[x]].cap);
x=edge[w[x]^1].to;
}
ans+=flow*dist[t];
x=t;
while (x!=s) {
edge[w[x]].cap-=flow;
edge[w[x]^1].cap+=flow;
x=edge[w[x]^1].to;
}
}
}
int dis[maxn][maxn],f[maxn][maxn],id[maxn][2];
int main(){
int n,m,k;
scanf("%d%d%d",&n,&m,&k);
memset(f,10,sizeof(f));
inf=f[0][0];
for (int i=1;i<=m;i++) {
int x,y,z;
scanf("%d%d%d",&x,&y,&z);
f[x][y]=f[y][x]=min(f[x][y],z);
}
for (int i=0;i<=n;i++) f[i][i]=0;
for (int k=0;k<=n;k++) {
for (int i=0;i<=n;i++)
for (int j=0;j<=n;j++)
f[i][j]=min(f[i][j],f[i][k]+f[k][j]);
for (int i=0;i<=n;i++) dis[i][k]=f[i][k];
}
for (int i=0;i<=n;i++) id[i][0]=++cnt;
for (int i=0;i<=n;i++) id[i][1]=++cnt;
int s=++cnt,t=++cnt;
addedge(id[0][0],id[0][1],k,0);
for (int i=1;i<=n;i++) {
addedge(id[0][1],id[i][0],inf,dis[0][i]);
addedge(id[i][1],id[n][1],inf,0);
addedge(id[i][0],id[i][1],inf,0);
addedge(s,id[i][1],1,0);
addedge(id[i][0],t,1,0);
}
for (int i=0;i<n;i++)
for (int j=i+1;j<=n;j++)
if (dis[i][j]!=inf) addedge(id[i][1],id[j][0],inf,dis[i][j]);
addedge(id[n][1],id[0][0],inf,0);
mcmf(s,t);
next[s]=next[t]=0;
next[id[n][1]]=edge[next[id[n][1]]].next;
next[id[0][0]]=edge[next[id[0][0]]].next;
mcmf(id[0][0],id[n][1]);
printf("%d\n",ans);
return 0;
}
BZOJ 2324: [ZJOI2011]营救皮卡丘(带上下限的最小费用最大流)的更多相关文章
- bzoj 2324 [ZJOI2011]营救皮卡丘(floyd,费用流)
2324: [ZJOI2011]营救皮卡丘 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1777 Solved: 712[Submit][Stat ...
- BZOJ 2324: [ZJOI2011]营救皮卡丘( floyd + 费用流 )
昨晚写的题...补发一下题解... 把1~N每个点拆成xi, yi 2个. 预处理i->j经过编号不超过max(i,j)的最短路(floyd) S->0(K, 0), S->xi(1 ...
- BZOJ.2324.[ZJOI2011]营救皮卡丘(费用流 Floyd)
BZOJ 洛谷 首先预处理出\(dis[i][j]\),表示从\(i\)到\(j\)的最短路.可以用\(Floyd\)处理. 注意\(i,j\)是没有大小关系限制的(\(i>j\)的\(dis[ ...
- bzoj 2324: [ZJOI2011]营救皮卡丘
#include<cstdio> #include<iostream> #include<cstring> #include<cmath> #inclu ...
- bzoj 2324 ZJOI 营救皮卡丘 费用流
题的大概意思就是给定一个无向图,边有权值,现在你有k个人在0点,要求走到n点,且满足 1:人们可以分头行动,可以停在某一点不走了 2:当你走到x时,前x-1个点必须全部走过(不同的人走过也行,即分两路 ...
- BZOJ2324 ZJOI2011营救皮卡丘(floyd+上下界费用流)
虽然不一定每次都是由编号小的点向编号大的走,但一个人摧毁的顺序一定是从编号小的到编号大的.那么在摧毁据点x的过程中,其只能经过编号小于x的点.并且这样一定合法,因为可以控制其他人先去摧毁所经过的点.那 ...
- BZOJ2324: [ZJOI2011]营救皮卡丘
2324: [ZJOI2011]营救皮卡丘 Time Limit: 10 Sec Memory Limit: 256 MBSubmit: 1359 Solved: 522[Submit][Stat ...
- 【BZOJ2324】[ZJOI2011]营救皮卡丘(网络流,费用流)
[BZOJ2324][ZJOI2011]营救皮卡丘(网络流,费用流) 题面 BZOJ 洛谷 题解 如果考虑每个人走的路径,就会很麻烦. 转过来考虑每个人破坏的点集,这样子每个人可以得到一个上升的序列. ...
- 【BZOJ2324】[ZJOI2011]营救皮卡丘 有上下界费用流
[BZOJ2324][ZJOI2011]营救皮卡丘 Description 皮卡丘被火箭队用邪恶的计谋抢走了!这三个坏家伙还给小智留下了赤果果的挑衅!为了皮卡丘,也为了正义,小智和他的朋友们义不容辞的 ...
随机推荐
- [转载] centos6.x x64 安装python2.7
本文转载自: http://www.centoscn.com/image-text/install/2016/0323/6906.html CentOS的设计理念中有一点是:持久可用.要达到这个目的, ...
- Nodejs之package.json介绍说明
规范的package.json及package.json中各属性的作用. "name":包名. "description":包简介. "author& ...
- Centos下wget下载整个网站,或者目录全部文件
需要下载某个目录下面的所有文件.命令如下 wget -c -r -np -k -L -p www.xxx.org/pub/path/ 在下载时.有用到外部域名的图片或连接.如果需要同时下载就要用-H参 ...
- Jenkins搭建Windows slave 环境
因为之前的接口测试平台是在windows上,后来换了linux,花了半天时间也没有成功,就想着建立一个windows的节点曲线救国 创建WindowsSlave 首先要保证windows和sl ...
- linux apache 打模块示例
主要是为了以后能举一反三 Apache配置方案 首先,安装apache的一个第三方模块“mod_rpaf”, 官方网站: http://stderr.net/apache/rpaf/ wget htt ...
- jQuery 的 ready 函数是如何工作的?(源码分析)
如果你使用过 jQuery , 就必然使用过 ready 函数,它用来注册当页面准备好之后可以执行的函数. 问题来啦,我们的页面什么时候准备好了呢? 1. onload 事件 最基本的处理方式就是页面 ...
- depcomp: line 571: exec: g++: not found
../depcomp: line 571: exec: g++: not foundmake[1]: *** [my_new.o] Error 127make[1]: Leaving director ...
- Raphael的拖动处理
Raphael的拖动处理: <%@ page language="java" contentType="text/html; charset=UTF-8" ...
- 浅谈Socket长连+多线程[原创,欢迎指点]
前戏 [PS:原文手打,转载说明出处] [PS:博主自认为适用于云平台设备管控,且适用于IM主控] 好久没来了,13年时还想着多写一些博客,这都17年过年,年前也写一写Scoket+多线程,不足之处, ...
- Word常用实用知识3
纯手打,可能有错别字,使用的版本是office Word 2013 转载请注明出处 http://www.cnblogs.com/hnnydxgjj/p/6322813.html,谢谢. 分页符分页 ...