BZOJ-2561-最小生成树 题解(最小割)

时间:2022-01-15 12:48:51

2561: 最小生成树(题解)

Time Limit: 10 Sec  Memory Limit: 128 MB
Submit: 1628  Solved: 786

传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=2561

Description

 给定一个边带正权的连通无向图G=(V,E),其中N=|V|,M=|E|,N个点从1到N依次编号,给定三个正整数u,v,和L (u≠v),假设现在加入一条边权为L的边(u,v),那么需要删掉最少多少条边,才能够使得这条边既可能出现在最小生成树上,也可能出现在最大生成树上?

Input

第一行包含用空格隔开的两个整数,分别为N和M;
接下来M行,每行包含三个正整数u,v和w表示图G存在一条边权为w的边(u,v)。
最后一行包含用空格隔开的三个整数,分别为u,v,和 L;
数据保证图中没有自环。

Output

输出一行一个整数表示最少需要删掉的边的数量。

Sample Input

3 2
3 2 1
1 2 3
1 2 2

Sample Output

1

HINT

对于20%的数据满足N ≤ 10,M ≤ 20,L ≤ 20;

对于50%的数据满足N ≤ 300,M ≤ 3000,L ≤ 200;

对于100%的数据满足N ≤ 20000,M ≤ 200000,L ≤ 20000。

 
【解析】
我们首先回忆一下kruskal算法求MST。。。
然后反过来想:如果一条边在MST上,那么权值小于它的边肯定做不出一个生成树。
之后就简单了:对于在最小生成树上,肯定是要在权值小于它的边中删掉一些使得剩下的不能做成一个生成树,也就是使要加入的边的两个端点在图中不连通。
我们想到了最小割!
要加入的边的两个端点分别是源与汇,然后每条小于其的边(注意:这是在MST上,在最大生成树上也同理,即处理大于它的边)的两个端点在图中连一条权值为1的无向边。然后最小割即可。
最终将在最小生成树与最大生成树上的处理的最小割的值相加即为所求。
我的程序452 MS,目前进排行榜前15啦~
 
ISAP~
#include<iostream>
#include<fstream>
#include<cstdio>
#include<algorithm>
#include<string>
#include<vector>
#include<queue>
#include<deque>
#include<utility>
#include<map>
#include<set>
#include<cmath>
#include<cstdlib>
#include<ctime>
#include<functional>
#include<sstream>
#include<cstring>
#include<bitset>
#include<stack>
using namespace std; int n,m,s,t,cnt,x,y,z,ansx,l;
struct sdt
{
int cap,flow,u,v;
}e[400005];
struct bdq
{
int a,b,c;
}edge[200005];
int nxt[400005],fir[20005],d[20005],par[20005],num[20005],cur[20005];
bool vis[20005]; int read()
{
int x=0;char c=getchar();
while(c<48||c>57)c=getchar();
while(c>47&&c<58)x*=10,x+=c-48,c=getchar();
return x;
} void bfs()
{
memset(vis,0,sizeof(vis));
memset(d,0,sizeof(d));
queue<int>q;
d[t]=0;
vis[t]=1;
q.push(t);
while(!q.empty())
{
int k=q.front();
q.pop();
for(int i=fir[k];i;i=nxt[i])
{
if(!vis[e[i].v])
{
vis[e[i].v]=1;
d[e[i].v]=d[k]+1;
q.push(e[i].v);
}
}
}
} int agument()
{
int p=t;
int ans=2147483647;
while(p!=s)
{
ans=min(ans,e[par[p]].cap-e[par[p]].flow);
p=e[par[p]].u;
}
p=t;
while(p!=s)
{
e[par[p]].flow+=ans;
e[par[p]^1].flow-=ans;
p=e[par[p]].u;
}
return ans;
} int isap()
{
memset(num,0,sizeof(num));
int flow=0;
for(int i=1;i<=n;i++)
{
num[d[i]]++;
cur[i]=fir[i];
}
int p=s;
while(d[s]<n)
{
if(p==t)
{
flow+=agument();
p=s;
}
bool ok=0;
for(int i=cur[p];i;i=nxt[i])
{
if(e[i].cap>e[i].flow && d[p]==d[e[i].v]+1)
{
ok=1;
par[e[i].v]=i;
cur[p]=i;
p=e[i].v;
break;
}
}
if(!ok)
{
int mn=n-1;
for(int i=fir[p];i;i=nxt[i])
{
if(e[i].cap>e[i].flow)mn=min(mn,d[e[i].v]);
}
if(--num[d[p]]==0)break;
num[d[p]=mn+1]++;
cur[p]=fir[p];
if(p!=s)p=e[par[p]].u;
}
}
return flow;
} int main()
{
memset(nxt,0,sizeof(nxt));
memset(fir,0,sizeof(fir));
n=read();m=read();
cnt=1;
for(int i=1;i<=m;i++)
{
edge[i].a=read();edge[i].b=read();edge[i].c=read();
}
s=read();t=read();l=read();
for(int i=1;i<=m;i++)
{
if(edge[i].c<l)
{
x=edge[i].a;
y=edge[i].b;
e[++cnt].u=x;e[cnt].v=y;e[cnt].cap=1;e[cnt].flow=0;
nxt[cnt]=fir[x];fir[x]=cnt;
e[++cnt].u=y;e[cnt].v=x;e[cnt].cap=1;e[cnt].flow=0;
nxt[cnt]=fir[y];fir[y]=cnt;
}
}
bfs();
ansx+=isap();
cnt=1;
memset(nxt,0,sizeof(nxt));
memset(fir,0,sizeof(fir));
memset(e,0,sizeof(e));
for(int i=1;i<=m;i++)
{
if(edge[i].c>l)
{
x=edge[i].a;
y=edge[i].b;
e[++cnt].u=x;e[cnt].v=y;e[cnt].cap=1;e[cnt].flow=0;
nxt[cnt]=fir[x];fir[x]=cnt;
e[++cnt].u=y;e[cnt].v=x;e[cnt].cap=1;e[cnt].flow=0;
nxt[cnt]=fir[y];fir[y]=cnt;
}
}
bfs();
ansx+=isap();
printf("%d\n",ansx);
return 0;
}

  

BZOJ-2561-最小生成树 题解(最小割)的更多相关文章

  1. BZOJ 2561 最小生成树 &vert; 网络流 最小割

    链接 BZOJ 2561 题解 用Kruskal算法的思路来考虑,边(u, v, L)可能出现在最小生成树上,就是说对于所有边权小于L的边,u和v不能连通,即求最小割: 对于最大生成树的情况也一样.容 ...

  2. bzoj 2561&colon; 最小生成树【最小割】

    看错题了以为多组询问吓得不行-- 其实还挺好想的,就是数据范围一点都不网络流.把U作为s,V作为t,以最小生成树为例,(U,V,L)要在最小生成树上,就要求所有边权比L小的边不能连通(U,V)所在的联 ...

  3. BZOJ 2561&colon; 最小生成树【最小割&sol;最大流】

    Description 给定一个边带正权的连通无向图G=(V,E),其中N=|V|,M=|E|,N个点从1到N依次编号,给定三个正整数u,v,和L (u≠v),假设现在加入一条边权为L的边(u,v), ...

  4. BZOJ&lowbar;2561&lowbar;最小生成树&lowbar;最小割

    BZOJ_2561_最小生成树_最小割 题意: 给定一个边带正权的连通无向图G=(V,E),其中N=|V|,M=|E|,N个点从1到N依次编号,给定三个正整数u,v,和L (u≠v),假设现在加入一条 ...

  5. BZOJ 2561&colon; 最小生成树&lpar;最小割&rpar;

    U,V能在最小(大)生成树上,当且仅当权值比它小(大)的边无法连通U,V. 两次最小割就OK了. --------------------------------------------------- ...

  6. bzoj千题计划322:bzoj2561&colon; 最小生成树(最小割)

    https://www.lydsy.com/JudgeOnline/problem.php?id=2561 考虑Kruscal算法求最小生成树的流程 如果 u和v之间的长为L的边能出现在最小生成树里, ...

  7. BZOJ 2521&colon; &lbrack;Shoi2010&rsqb;最小生成树(最小割)

    题意 对于某一条无向图中的指定边 \((a, b)\) , 求出至少需要多少次操作.可以保证 \((a, b)\) 边在这个无向图的最小生成树中. 一次操作指: 先选择一条图中的边 \((u, v)\ ...

  8. 【bzoj2521】&lbrack;Shoi2010&rsqb;最小生成树 网络流最小割

    题目描述 Secsa最近对最小生成树问题特别感兴趣.他已经知道如果要去求出一个n个点.m条边的无向图的最小生成树有一个Krustal算法和另一个Prim的算法.另外,他还知道,某一个图可能有多种不同的 ...

  9. 【bzoj2561】最小生成树 网络流最小割

    题目描述 给定一个边带正权的连通无向图G=(V,E),其中N=|V|,M=|E|,N个点从1到N依次编号,给定三个正整数u,v,和L (u≠v),假设现在加入一条边权为L的边(u,v),那么需要删掉最 ...

  10. BZOJ2561 最小生成树 【最小割】

    题目 给定一个边带正权的连通无向图G=(V,E),其中N=|V|,M=|E|,N个点从1到N依次编号,给定三个正整数u,v,和L (u≠v),假设现在加入一条边权为L的边(u,v),那么需要删掉最少多 ...

随机推荐

  1. FZU 1759 欧拉函数 降幂公式

    Description   Given A,B,C, You should quickly calculate the result of A^B mod C. (1<=A,C<=1000 ...

  2. DNS加速之&OpenCurlyDoubleQuote;智能DNS”跟&OpenCurlyDoubleQuote;双线加速”、&OpenCurlyDoubleQuote;CDN加速”的区别

    “智能DNS”跟“双线加速”.“CDN加速”的区别相信,很大部分IDC用户可能还没弄清楚状况,有人觉得智能DNS跟双线加速.CDN加速是类似的技术.其实不然,它们在工作方式上有着本质的区别,但它们又可 ...

  3. django中form表单的提交:

    一,关于表单: 表单在百度百科的解释:   表单在网页中主要负责数据采集功能.一个表单有三个基本组成部分: 表单标签:这里面包含了处理表单数据所用CGI程序的URL以及数据提交到服务器的方法. 表单域 ...

  4. jquery&period;string&period;js

    /** * jquery.string - Prototype string functions for jQuery * version: 1.1.0 * (c) 2008-2011 David E ...

  5. HTML5&lowbar;图片合成&lowbar;刮刮卡

    刮刮卡(图片合成) 定义: globalCompositeOperation 属性,设置或返回如何将源图像 将 myCanvas 的背景图设置为一张图片,(刮开后显示) // 目标图像(已有的,外面一 ...

  6. jmeter配置脚本录制进行抓包并快速分析、定位接口问题

    对于测试人员.开发人员来说,善用抓包工具确实是快速分析和定位问题的一大必备神技,现将配置过程记录如下: 1.打开jmeter后,首先添加一个线程组: 2.线程组可以重新命名按项目名称分类 3.然后在工 ...

  7. PAT 乙级 1092 最好吃的月饼 (20 分)

    1092 最好吃的月饼 (20 分) 月饼是久负盛名的中国传统糕点之一,自唐朝以来,已经发展出几百品种. 若想评比出一种“最好吃”的月饼,那势必在吃货界引发一场腥风血雨…… 在这里我们用数字说话,给出 ...

  8. sql server&colon;Monty Hall problem &lpar;蒙提霍尔问题&rpar;

    --------------------------------------------------------------------- -- Auxiliry Table of Numbers 数 ...

  9. 牛客网NOIP赛前集训营-提高组(第八场)-B-推箱子&lbrack;最短路优化建图&rsqb;

    题意 有 \(n\) 个箱子,指定一个箱子开始向右推,如果碰到了别的箱子会令其移动,问 \(k\) 秒之后每个箱子所在的位置. \(n\leq 10^5\). 分析 转化成最短路模型,如果两个箱子 \ ...

  10. jmeter监控服务器的方法

    先下载Jmeter资源监控插件,我的百度云jmeter视频里面有说. 地址如下: JMeterPlugins-Standard-1.3.1.zip  下载 https://jmeter-plugins ...