思路:

首先 先Dijkstra一遍 找出来最短路

不是最短路上的边都不要

然后呢 套个Dinic模板就好了……

求个最小割

输出

大功告成~~

//By SiriusRen
#include <queue>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
#define N 22222
int n,m,xx,yy,zz,first[N],tot,dis[N],vis[N],ans,cases;
struct Edge{int v,w,next;}edge[N];
struct Node{int now,weight;}jy;
void add(int xx,int yy,int zz){
edge[tot].v=yy,edge[tot].w=zz;
edge[tot].next=first[xx],first[xx]=tot++;
}
bool operator < (Node a,Node b){return a.weight>b.weight;}
void Dijkstra(int from){
memset(vis,0,sizeof(vis));
memset(dis,0x3f,sizeof(dis));
dis[from]=0;
priority_queue<Node>pq;
jy.now=from,jy.weight=0;
pq.push(jy);
while(!pq.empty()){
Node t=pq.top();pq.pop();
if(vis[t.now])continue;
vis[t.now]=1;
for(int i=first[t.now];~i;i=edge[i].next)
if(!vis[edge[i].v]&&dis[edge[i].v]>dis[t.now]+1){
dis[edge[i].v]=dis[t.now]+1;
jy.now=edge[i].v;jy.weight=t.weight+1;
pq.push(jy);
}
}
}
struct Dinic{
int v[N],next[N],w[N],fst[N],cnt;
void init(){memset(fst,-1,sizeof(fst)),cnt=0;}
void add(int x,int y,int z){
w[cnt]=z,v[cnt]=y;
next[cnt]=fst[x],fst[x]=cnt++;
}
bool tell(){
memset(vis,-1,sizeof(vis));
queue<int>q;
q.push(1),vis[1]=0;
while(!q.empty()){
int t=q.front();q.pop();
for(int i=fst[t];~i;i=next[i]){
if(w[i]&&vis[v[i]]==-1)
q.push(v[i]),vis[v[i]]=vis[t]+1;
}
}
return vis[n]!=-1;
}
int zeng(int x,int y){
if(x==n||!y)return y;
int r=0;
for(int i=fst[x];~i&&y>r;i=next[i])
if(w[i]&&vis[v[i]]==vis[x]+1){
int t=zeng(v[i],min(y-r,w[i]));
w[i]-=t,w[i^1]+=t,r+=t;
}
if(!r)vis[x]=-1;
return r;
}
void flow(){
while(tell())while(xx=zeng(1,0x3fffffff))ans+=xx;
printf("%d\n",ans);
}
}dinic;
int main(){
scanf("%d",&cases);
while(cases--){
memset(first,-1,sizeof(first)),tot=ans=0;
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++){
scanf("%d%d%d",&xx,&yy,&zz);
add(xx,yy,zz),add(yy,xx,zz);
}
Dijkstra(1),dinic.init();
for(int i=1;i<=n;i++)
for(int j=first[i];~j;j=edge[j].next)
if(dis[edge[j].v]==dis[i]+1){
dinic.add(i,edge[j].v,edge[j].w);
dinic.add(edge[j].v,i,0);
}
dinic.flow();
}
}

最新文章

  1. iOS屏幕旋转
  2. asp.net中关于Microsoft 信息完整性、隐私性等集成信息安全服务服务 integrated security=SSPI
  3. filter应用案例一:分IP统计访问次数
  4. [转]JVM 内存初学 (堆(heap)、栈(stack)和方法区(method) )
  5. Linux Kernel File IO Syscall Kernel-Source-Code Analysis(undone)
  6. spoj 362
  7. python的内存管理机制 图解+Django Web开发学习笔记
  8. python读取excel文件
  9. C#获取本机IP搜集整理7种方法
  10. 2661: [BeiJing wc2012]连连看
  11. linux防火墙 基础知识
  12. Redis源代码分析(十)--- testhelp.h小测试框架和redis-check-aof.c 日志检测
  13. 关于ftp的学习:ftp很多人都会用。但会用,不代表我们真正了解它。
  14. ActiveMQ(七)_伪集群和主从高可用使用(转)
  15. [rhel]安装oracle11g
  16. JavaEE基本框架(Struts2+Spring+MyBatis三层,Struts MVC)之间的关系
  17. ADB文件及文件夹操作
  18. /etc/services
  19. Zip文件格式
  20. 为什么说git比svn好

热门文章

  1. 通过唯一ID实现简单的日志跟踪实现
  2. 紫书 例题 11-2 UVa 1395(最大边减最小边最小的生成树)
  3. 第一个JavaWeb工程
  4. SpringBoot之通过Maven将项目打包成ROOT.war-yellowcong
  5. Material Design学习之 Button(具体分析,传说中的水滴动画)
  6. C语言打印100以内的质数
  7. 又见关系并查集 以POJ 1182 食物链为例
  8. 一个使用sbt编译的JNI C++ 的模板
  9. hdu_1166,线段树单点更新
  10. Windows安装PHP MongoDB扩展