博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
洛谷P3376【模板】网络最大流  Dinic模板
阅读量:4653 次
发布时间:2019-06-09

本文共 1141 字,大约阅读时间需要 3 分钟。

之前的Dinic模板照着刘汝佳写的vector然后十分鬼畜跑得奇慢无比,虽然别人这样写也没慢多少但是自己的就是令人捉急。

改成邻接表之后快了三倍,虽然还是比较慢但是自己比较满意了。虽然一开始ecnt从0开始WA了一发。。。

之前的码风也十分鬼畜呀缩进只缩1、2格不懂自己怎么想的。。

反正今天就安心划划水。

#include
#include
#include
#include
#include
#include
#include
typedef long long LL;const int maxn=20050,maxm=200050,INF=0x7f7f7f7f;using namespace std;int n,m,s,t,u,v,w,ecnt=1,fir[maxn],dis[maxn],cur[maxn],ans;struct edge { int from,to,cap,flow,nxt; edge(){} edge(int from,int to,int cap,int flow,int nxt):from(from),to(to),cap(cap),flow(flow),nxt(nxt){}}e[maxm];void add(int u,int v,int w) { e[++ecnt]=edge(u,v,w,0,fir[u]); e[++ecnt]=edge(v,u,0,0,fir[v]); fir[u]=ecnt-1; fir[v]=ecnt;}void init() { scanf("%d%d%d%d",&n,&m,&s,&t); for(int i=1;i<=m;i++) { scanf("%d%d%d",&u,&v,&w); add(u,v,w); }}queue
que;int bfs(int s,int t) { memset(dis,0,sizeof(dis)); dis[s]=1; que.push(s); while(!que.empty()) { int x=que.front() ;que.pop(); for(int i=fir[x];i;i=e[i].nxt) if(!dis[e[i].to]&&e[i].flow
View Code

 

转载于:https://www.cnblogs.com/Achenchen/p/7534817.html

你可能感兴趣的文章
Objective-C ,ios,iphone开发基础:ios数据库(The SQLite Database),使用终端进行简单的数据库操作...
查看>>
好吧,如果一定要RESTFUL的DJANGO
查看>>
Java类的执行顺序
查看>>
Why ngx-uploader doesn't like to cooperate with .net core 2.x?
查看>>
iOS-Senior20-Map定位
查看>>
Apache本地环境部署
查看>>
开发模式接入
查看>>
java 中的复制(将D盘中的文件复制到E盘中)
查看>>
【原创】谈谈redis的热key问题如何解决
查看>>
LoadLibrary 失败 GetLastError 126
查看>>
Monty Hall 问题与贝叶斯定理的理解
查看>>
利用JavaScript的字符串操作实现简单查字
查看>>
安全发布的模式
查看>>
python的N个小功能(更新文件)
查看>>
【bzoj 4390】 [Usaco2015 dec]Max Flow(树上差分)
查看>>
java之sleep、wait、yield、join、notify乱解
查看>>
DEDECMS 关键字不能小于2个字节!
查看>>
Flutter学习笔记(10)--容器组件、图片组件
查看>>
gitlab 的使用策略和简单介绍
查看>>
Web.py Cookbook 简体中文版 - 保存上传的文件
查看>>