[hdu6582]Path
首先,从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的更多相关文章
- HDU6582 Path【优先队列优化最短路 + dinic最大流 == 最小割】
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6582 来源:2019 Multi-University Training Contest 1 题目大意 ...
- [2019杭电多校第一场][hdu6582]Path(最短路&&最小割)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6582 题意:删掉边使得1到n的最短路改变,删掉边的代价为该边的边权.求最小代价. 比赛时一片浆糊,赛后 ...
- hdu多校第一场1005(hdu6582)Path 最短路/网络流
题意: 在无向图上删边,让此图上从起点到终点的最短路长度变大,删边的代价是边长,求最小代价. 题解: 先跑一遍迪杰斯特拉,求出所有点的d[]值,然后在原图上保留所有的边(i,j)仅当i,j满足d[j] ...
- 【2019多校第一场补题 / HDU6582】2019多校第一场E题1005Path——最短路径+网络流
HDU6582链接 题意 在一张有向图中,有一个起点和一个终点,你需要删去部分路径,使得起点到终点的最短距离增加(并不要求需要使得距离变成最大值),且删除的路径长度最短.求删去的路径总长为多少 分析 ...
- NodeJs之Path
Path模块 NodeJs提供的Path模块,使得我们可以对文件路径进行简单的操作. API var path = require('path'); var path_str = '\\Users\\ ...
- 【原】实时渲染中常用的几种Rendering Path
[原]实时渲染中常用的几种Rendering Path 本文转载请注明出处 —— polobymulberry-博客园 本文为我的图形学大作业的论文部分,介绍了一些Rendering Path,比较简 ...
- Node.js:path、url、querystring模块
Path模块 该模块提供了对文件或目录路径处理的方法,使用require('path')引用. 1.获取文件路径最后部分basename 使用basename(path[,ext])方法来获取路径的最 ...
- VSCode调试go语言出现:exec: "gcc": executable file not found in %PATH%
1.问题描述 由于安装VS15 Preview 5,搞的系统由重新安装一次:在用vscdoe编译go语言时,出现以下问题: # odbcexec: "gcc": executabl ...
- 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 ...
随机推荐
- Java JDK的下载与安装!Java基础
在了解什么是Java.Java 语言的特点以及学习方法之后,本节将介绍如何搭建编写 Java 程序所需要的开发环境--JDK,只有搭建了环境才能敲代码! 学Java的都知道,JDK 是一种用于构建在 ...
- 寻找最佳路径(ArcPy实现)
一.背景 随着社会经济发展需求,公路的重要性日益提高.在一些交通欠发达的地区,公路建设迫在眉睫.如何根据实际地形情况设计出比较合理的公路规划,是一个值得研究的问题. 二.实验目的: (1)通过练习,熟 ...
- 题解 「2017 山东一轮集训 Day5」苹果树
题目传送门 题目大意 给出一个 \(n\) 个点的图,每个点都有一个权值 \(f_i\) ,如果 \(f_i=-1\) 表示 \(i\) 这个点是坏的.定义一个点是有用的当且仅当它不是坏的,并且它连的 ...
- 好程序员打造核心教培天团,着力培养IT高级研发人才
随着数字化进程加快,各行各业数字化转型迫在眉睫,技术人才战略成为企业发力重点,IT高级研发人才已经成为企业的"核心资产",对企业发展起关键性作用,然而市场上高级研发人才极为稀缺.据 ...
- vue.$nextTick实现原理
源码: const callbacks = [] let pending = false function flushCallbacks () { pending = false const copi ...
- 【UE4】基础概念——文件结构、类型、反射、编译、接口、垃圾回收、序列化
新标签打开或者下载看大图 思维导图 Engine Structure Pipeline Programming Pipeline Blueprint Pipeline
- 认真讲说static关键字
static 关键字主要有以下四种使用场景 修饰成员变量和成员方法 静态代码块 修饰类(只能修饰内部类) 静态导包(用来导入类中的静态资源,1.5之后的新特性) 修饰成员变量和成员方法(常用) 被 s ...
- Taylor公式原来可以这么简单
1.Taylor公式 解决:含有高阶导数的中值定理或定积分.极限运算等题目 条件:f(x)在x=x0领域内(n+1)阶可导 结论:f(x)=Pn(x)+Rn(x) 2.x和x0的取值 3.Taylor ...
- TT模板的作用及使用
一.假如你在ef中添加一个实体,没有模板,你需要在DAL层中新建一个"莫某Dal"和"I某某Dal"以及在公共的DbSession中加你的这个dal,然后需要在 ...
- 利用Microsoft Graph开发微软的Exchange Calendar会议、Team
Microsoft Graph是什么? Microsoft Graph 是 Microsoft 365 中通往数据和智能的网关. 它提供统一的可编程模型,可用于访问 Microsoft 365.Win ...