这道题么= =还是有些恶心的,第一次写带上下界的网络流,整个人都萌萌哒~~~

首先先预处理得最短路后

直接用费用流做就行了。

第一次写,还是挺好写的= =

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]营救皮卡丘(带上下限的最小费用最大流)的更多相关文章

  1. bzoj 2324 [ZJOI2011]营救皮卡丘(floyd,费用流)

    2324: [ZJOI2011]营救皮卡丘 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1777  Solved: 712[Submit][Stat ...

  2. BZOJ 2324: [ZJOI2011]营救皮卡丘( floyd + 费用流 )

    昨晚写的题...补发一下题解... 把1~N每个点拆成xi, yi 2个. 预处理i->j经过编号不超过max(i,j)的最短路(floyd) S->0(K, 0), S->xi(1 ...

  3. BZOJ.2324.[ZJOI2011]营救皮卡丘(费用流 Floyd)

    BZOJ 洛谷 首先预处理出\(dis[i][j]\),表示从\(i\)到\(j\)的最短路.可以用\(Floyd\)处理. 注意\(i,j\)是没有大小关系限制的(\(i>j\)的\(dis[ ...

  4. bzoj 2324: [ZJOI2011]营救皮卡丘

    #include<cstdio> #include<iostream> #include<cstring> #include<cmath> #inclu ...

  5. bzoj 2324 ZJOI 营救皮卡丘 费用流

    题的大概意思就是给定一个无向图,边有权值,现在你有k个人在0点,要求走到n点,且满足 1:人们可以分头行动,可以停在某一点不走了 2:当你走到x时,前x-1个点必须全部走过(不同的人走过也行,即分两路 ...

  6. BZOJ2324 ZJOI2011营救皮卡丘(floyd+上下界费用流)

    虽然不一定每次都是由编号小的点向编号大的走,但一个人摧毁的顺序一定是从编号小的到编号大的.那么在摧毁据点x的过程中,其只能经过编号小于x的点.并且这样一定合法,因为可以控制其他人先去摧毁所经过的点.那 ...

  7. BZOJ2324: [ZJOI2011]营救皮卡丘

    2324: [ZJOI2011]营救皮卡丘 Time Limit: 10 Sec  Memory Limit: 256 MBSubmit: 1359  Solved: 522[Submit][Stat ...

  8. 【BZOJ2324】[ZJOI2011]营救皮卡丘(网络流,费用流)

    [BZOJ2324][ZJOI2011]营救皮卡丘(网络流,费用流) 题面 BZOJ 洛谷 题解 如果考虑每个人走的路径,就会很麻烦. 转过来考虑每个人破坏的点集,这样子每个人可以得到一个上升的序列. ...

  9. 【BZOJ2324】[ZJOI2011]营救皮卡丘 有上下界费用流

    [BZOJ2324][ZJOI2011]营救皮卡丘 Description 皮卡丘被火箭队用邪恶的计谋抢走了!这三个坏家伙还给小智留下了赤果果的挑衅!为了皮卡丘,也为了正义,小智和他的朋友们义不容辞的 ...

随机推荐

  1. MMA

    在32位的系统上,线性地址空间可达到4GB,这4GB一般按照3:1的比例进行分配,也就是说用户进程享有前3GB线性地址空间,而内核独享最后1GB线性地址空间.由于虚拟内存的引入,每个进程都可拥有3GB ...

  2. NPM 简单实用说明

    https://nodejs.org/en/download/ 下载并按照,直接下一步就可以,最后会在C:\Program Files 新建一个nodejs文件夹,里面有一个node.exe.双击就启 ...

  3. Core Data 应用程序实践指南(Core Data 应用程序实践指南)

    译者序 前言 勘误 1. 初次尝试Core Data应用程序 本书的基础,基本概念,能做什么,不能做什么.实现CoreDataHelper类,演示如何将Core Data同既有的应用程序相集成. 2. ...

  4. layer弹窗插件实战用法小结1—— layer.alert()

    http://layer.layui.com 第一节:layer.alert()弹窗的用法 1.解压layer-v2.2.zip压缩包 2.拷贝layer文件夹到实战项目目录 3.注意:layer.j ...

  5. mysql 常用技巧

    1.正则使用 比 LIKE 会牺牲很多的系统资源 尽量不要用 正则的语法和JS PHP 差不多 select * from t1 where email REGEXP "@163[,.]co ...

  6. Angularjs在线api文档

    http://docs.ngnice.com/api            文档 http://www.ngnice.com/showcase/#/home/home                  ...

  7. C# 从字符串向 datetime 转换时失败

    更改电脑的日期类型即可,把短日期和长日期修改下面的样子即可:

  8. 第二部分 条件控制执行语句、循环语句、switch语句、跳转语句和其它语句

    条件控制执行语句: if语句 if....else....语句 循环语句: while语句 do....while语句 for语句 switch语句: 跳转语句: break; continue; r ...

  9. NetStream.appendBytes, 走向Flash P2P VOD的第一步

    之前被告知可以自行实现Flash p2p的点播功能, 但一直疑惑, 印象中NetStream并未提供相关方法, 前天看订阅时发现的文章: ByteArray Access to NetStream i ...

  10. 在ubuntu linux 中编写一个自己的python脚本

    在ubuntu linux 中编写一个自己的简单的bash脚本. 实现功能:终端中输入简单的命令(以pmpy为例(play music python),为了区别之前说的bash脚本添加了py后缀),来 ...