正题

题目链接:https://www.luogu.com.cn/problem/P5934


题目大意

给出\(n\)个点\(m\)条边的一张图,再加入一条边\((u,v,L)\)求至少删掉多少条边可以使得这条边即在最小生成树上又在最大生成树上。

\(1\leq n\leq 2\times 10^4,1\leq m\leq 2\times 10^5\)


解题思路

稍微思考一下就不难发现这两个问其实是没有影响的,因为第一个问显然只需要删去边权小于\(L\)的,第二个问显然只需要删去边权大于\(L\)的。所以考虑分开求然后相加

那么考虑怎么让它在最小生成树上。考虑我们之前\(\text{LCT}\)维护最小生成树的做法,我们加入一条边\((u,v,w)\)的时候,是找到\(u\sim v\)路径上的最大边然后和\(w\)比较。

那么如果原图中存在一条不经过这条边的路径且最大值比\(u,v\)要小。那么显然这条路径可以完全取代这条边,所以这条边一定不是最小生成树上的边。

那么同理我们只需要把所有边权小于\(L\)的边加入,然后再删去最少的边使得\(u,v\)不连通即可。这个用最小割解决就好了。

最大生成树同理


code

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
using namespace std;
const int N=2e4+10,M=2e5+10,inf=1e9;
struct node{
int to,next,w;
}a[M<<1];
struct edge{
int x,y,w;
}e[M];
int n,m,s,t,L,tot=1,ls[N],dep[N],ans;
queue<int> q;
void addl(int x,int y,int w){
a[++tot].to=y;a[tot].next=ls[x];ls[x]=tot;a[tot].w=w;
a[++tot].to=x;a[tot].next=ls[y];ls[y]=tot;a[tot].w=w;
return;
}
bool bfs(){
while(!q.empty())q.pop();q.push(s);
memset(dep,0,sizeof(dep));dep[s]=1;
while(!q.empty()){
int x=q.front();q.pop();
for(int i=ls[x];i;i=a[i].next){
int y=a[i].to;
if(dep[y]||!a[i].w)continue;
dep[y]=dep[x]+1;
if(y==t)return 1;
q.push(y);
}
}
return 0;
}
int dinic(int x,int flow){
if(x==t)return flow;
int rest=0,k;
for(int i=ls[x];i;i=a[i].next){
int y=a[i].to;
if(dep[x]+1!=dep[y]||!a[i].w)continue;
rest+=(k=dinic(y,min(flow-rest,a[i].w)));
a[i].w-=k;a[i^1].w+=k;
if(rest==flow)return flow;
}
if(!rest)dep[x]=0;
return rest;
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=m;i++)
scanf("%d%d%d",&e[i].x,&e[i].y,&e[i].w);
scanf("%d%d%d",&s,&t,&L);
for(int i=1;i<=m;i++)
if(e[i].w<L)addl(e[i].x,e[i].y,1);
while(bfs())
ans+=dinic(s,inf);
memset(ls,0,sizeof(ls));tot=0;
for(int i=1;i<=m;i++)
if(e[i].w>L)addl(e[i].x,e[i].y,1);
while(bfs())
ans+=dinic(s,inf);
printf("%d\n",ans);
return 0;
}

最新文章

  1. a0=1、a1=1、a2=a1+a0、a3=a2+a1,以此类推,请写代码用递归算出a30?
  2. 原创:C语言打开、下载、删除网页,统计网页字符个数
  3. Linux 信号详解六(可靠信号与不可靠信号)
  4. BZOJ 1116: [POI2008]CLO
  5. 未能加载文件或程序集“Interop.jmail”或它的某一个依赖项
  6. 在现代渲染API下,封装跨平台渲染框架的尝试 - 资源管理
  7. android studio集成ijkplayer
  8. UOJ207:共价大爷游长沙
  9. luogu 2157 状压dp
  10. vscode快捷键大全
  11. 『Python CoolBook』Cython_高效数组操作
  12. Scrapy实战篇(五)之爬取历史天气数据
  13. linux环境下tomcat安装
  14. 保留最新N份备份目录脚本
  15. Python-元组-10
  16. python 线程 event
  17. 前端-CSS-8-浮动与清楚浮动(重点)
  18. java之子类继承抽象类,子类构造器调用抽象类构造器问题
  19. Java解析Json数据的两种方式
  20. 深入浅出CSS(一):line-height与vertical-align的性质

热门文章

  1. windows10磁盘分区后,如何恢复分区,回到未分区之前
  2. 利用Java进行zip文件压缩与解压缩
  3. DataTemplateSelector介绍
  4. 并发编程之:synchronized
  5. for循环操作(for...in、forEach)
  6. form表单中id与name的区别
  7. linux centos7 模拟垃圾回收站功能以及 crontab 定时任务的设置
  8. JavaScript高级程序设计(读书笔记)之BOM
  9. 基于Bootstrap v4.1.1 &amp; Bootstrap-table-1.14.1实现数据瀑布流
  10. noip模拟39