首先,从1和n跑一次dij,判断每一条边能否出现在最短路上,不能出现就删掉,然后将所有边建在图上,流量为边权,跑最小割即可。

  1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 10005
4 #define ll long long
5 struct ji{
6 int nex,to,len;
7 }edge[N<<1];
8 vector<ji>v;
9 queue<int>q;
10 int E,t,n,m,x,y,z,head[N],d[N],work[N];
11 ll d1[N],d2[N];
12 struct ji2{
13 int k;
14 bool operator < (const ji2 &a)const{
15 return d1[k]>d1[a.k];
16 }
17 };
18 priority_queue<ji2>qq;
19 void add(int x,int y,int z){
20 edge[E].nex=head[x];
21 edge[E].to=y;
22 edge[E].len=z;
23 head[x]=E++;
24 }
25 void dij(int k){
26 memset(d1,0x3f,sizeof(d1));
27 qq.push(ji2{k});
28 d1[k]=0;
29 while (!qq.empty()){
30 k=qq.top().k;
31 qq.pop();
32 for(int i=head[k];i!=-1;i=edge[i].nex){
33 if (d1[k]+edge[i].len<d1[edge[i].to]){
34 d1[edge[i].to]=d1[k]+edge[i].len;
35 qq.push(ji2{edge[i].to});
36 }
37 }
38 }
39 }
40 bool bfs(){
41 memset(d,-1,sizeof(d));
42 q.push(1);
43 d[1]=0;
44 while (!q.empty()){
45 int k=q.front();
46 q.pop();
47 for(int i=head[k];i!=-1;i=edge[i].nex){
48 int v=edge[i].to;
49 if ((edge[i].len)&&(d[v]<0)){
50 d[v]=d[k]+1;
51 q.push(v);
52 }
53 }
54 }
55 return d[n]>=0;
56 }
57 int dfs(int k,int s){
58 if (k==n)return s;
59 int p;
60 for(int i=work[k];i!=-1;i=edge[i].nex){
61 int v=edge[i].to;
62 if ((edge[i].len)&&(d[v]==d[k]+1)&&(p=dfs(v,min(s,edge[i].len)))){
63 edge[i].len-=p;
64 edge[i^1].len+=p;
65 work[k]=i;
66 return p;
67 }
68 }
69 work[k]=-1;
70 return 0;
71 }
72 ll dinic(){
73 int k;
74 ll ans=0;
75 while (bfs()){
76 memcpy(work,head,sizeof(head));
77 while (k=dfs(1,0x3f3f3f3f))ans+=k;
78 }
79 return ans;
80 }
81 int main(){
82 scanf("%d",&t);
83 while (t--){
84 scanf("%d%d",&n,&m);
85 if (n==1){
86 printf("0\n");
87 continue;
88 }
89 E=0;
90 memset(head,-1,sizeof(head));
91 v.clear();
92 for(int i=1;i<=m;i++){
93 scanf("%d%d%d",&x,&y,&z);
94 add(x,y,z);
95 v.push_back(ji{x,y,z});
96 }
97 dij(1);
98 memcpy(d2,d1,sizeof(d1));
99 E=0;
100 memset(head,-1,sizeof(head));
101 for(int i=0;i<v.size();i++)add(v[i].to,v[i].nex,v[i].len);
102 dij(n);
103 v.clear();
104 for(int i=1;i<=n;i++)
105 for(int j=head[i];j!=-1;j=edge[j].nex)
106 if (d1[i]+d2[edge[j].to]+edge[j].len==d1[1])v.push_back(ji{edge[j].to,i,edge[j].len});
107 E=0;
108 memset(head,-1,sizeof(head));
109 for(int i=0;i<v.size();i++){
110 add(v[i].nex,v[i].to,v[i].len);
111 add(v[i].to,v[i].nex,0);
112 }
113 printf("%lld\n",dinic());
114 }
115 }

[hdu6582]Path的更多相关文章

  1. HDU6582 Path【优先队列优化最短路 + dinic最大流 == 最小割】

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6582 来源:2019 Multi-University Training Contest 1 题目大意 ...

  2. [2019杭电多校第一场][hdu6582]Path(最短路&&最小割)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6582 题意:删掉边使得1到n的最短路改变,删掉边的代价为该边的边权.求最小代价. 比赛时一片浆糊,赛后 ...

  3. hdu多校第一场1005(hdu6582)Path 最短路/网络流

    题意: 在无向图上删边,让此图上从起点到终点的最短路长度变大,删边的代价是边长,求最小代价. 题解: 先跑一遍迪杰斯特拉,求出所有点的d[]值,然后在原图上保留所有的边(i,j)仅当i,j满足d[j] ...

  4. 【2019多校第一场补题 / HDU6582】2019多校第一场E题1005Path——最短路径+网络流

    HDU6582链接 题意 在一张有向图中,有一个起点和一个终点,你需要删去部分路径,使得起点到终点的最短距离增加(并不要求需要使得距离变成最大值),且删除的路径长度最短.求删去的路径总长为多少 分析 ...

  5. NodeJs之Path

    Path模块 NodeJs提供的Path模块,使得我们可以对文件路径进行简单的操作. API var path = require('path'); var path_str = '\\Users\\ ...

  6. 【原】实时渲染中常用的几种Rendering Path

    [原]实时渲染中常用的几种Rendering Path 本文转载请注明出处 —— polobymulberry-博客园 本文为我的图形学大作业的论文部分,介绍了一些Rendering Path,比较简 ...

  7. Node.js:path、url、querystring模块

    Path模块 该模块提供了对文件或目录路径处理的方法,使用require('path')引用. 1.获取文件路径最后部分basename 使用basename(path[,ext])方法来获取路径的最 ...

  8. VSCode调试go语言出现:exec: "gcc": executable file not found in %PATH%

    1.问题描述 由于安装VS15 Preview 5,搞的系统由重新安装一次:在用vscdoe编译go语言时,出现以下问题: # odbcexec: "gcc": executabl ...

  9. Leetcode 笔记 113 - Path Sum II

    题目链接:Path Sum II | LeetCode OJ Given a binary tree and a sum, find all root-to-leaf paths where each ...

随机推荐

  1. ElasticSearch7.X.X-初见-模仿京东搜索的实战

    目录 简介 聊聊Doug Cutting ES&Solr&Lucene ES的安装 安装可视化界面ES head插件 了解ELK 安装Kibana ES核心概念 文档 类型 索引 倒排 ...

  2. python爬虫时,解决编码方式问题的万能钥匙(uicode,utf8,gbk......)

    转载   原文:https://blog.csdn.net/xiongzaiabc/article/details/81008330 无论遇到的网页代码是何种编码方式,都可以用以下方法统一解决 imp ...

  3. javascript-jquery选择器

    jquery选择器用来获得jquery对象 我们用一个实例来演示jquery与原生的区别 <div id="title">123</div>原生获得元素的方 ...

  4. JavaScript04

    分离绑定事件 使用分离方式绑定元素事件可以使用页面元素与JavaScript代码完全分离,有利于代码分工和维护,是目前开发主流,分为两步: 1.获取需要绑定事件的元素 语法:根据id属性值取元素节点 ...

  5. 短短 29 天,应对高峰 100W+ 访问,看浙大如何交出满分答卷

    疫情期间"停课不停教,停课不停学",线上开课第一天,浙江大学网上开课平台访问量即突破100 万次,访客数3万余人,最高峰达 1.1万人同时在线,发起课程直播2000余场,然而系统却 ...

  6. Java Filter型内存马的学习与实践

    完全参考:https://www.cnblogs.com/nice0e3/p/14622879.html 这篇笔记,来源逗神的指点,让我去了解了内存马,这篇笔记记录的是filter类型的内存马 内存马 ...

  7. 在kivy中加图片

    from kivy.app import App from kivy.uix.scatterlayout import ScatterLayout from kivy.uix.image import ...

  8. AIApe问答机器人项目Scrum Meeting博客汇总

    荡起双桨 Scrum Meeting 博客汇总 一.Alpha阶段 AIApe问答机器人Scrum Meeting 4.23 AIApe问答机器人Scrum Meeting 4.25 AIApe问答机 ...

  9. dwr简单应用及一个反向ajax消息推送

    由于项目中最近需要用到dwr实现一些功能,因此在网上和dwr官网上找了一些资料进行学习.在此记录一下.(此处实现简单的dwr应用和dwr消息反向推送) 一.引入dwr的包 <dependency ...

  10. elasticsearch嵌套对象的映射

    在es中,我们有时候可能需要映射,{ "field" : "xx" , "field01" : [] }这样格式的嵌套对象,默认情况下es会 ...