洛谷P4180 [BJWC2010]严格次小生成树

2023-05-16

传送门

之前写过一次,但是理解不深刻,复习之后有了更加细节的一些理解

好了进入正题

首先,我们需要知道次小生成树一定是在最小生成树的邻集中,即次小生成树与最小生成树只会有一条边的差别

所以我们会想枚举所有非树边,看看哪条换进去可以得到次小生成树

而非树边去替换哪条树边又是一个问题,但是如果你注意到当前这条非树边与树上的一些树边构成了环——其实也就是这条非树边的两端点的LCA与之成环了

意识到这一点,问题就会简单许多,我们可以利用LCA中的倍增思想,维护路径上的权值最大边

事实上,我们还需要维护路径上的权值次大边——因为要求严格最小,不允许权值和相等(否则怎么叫次小呢),而如果权值最大边与我们枚举到的当前非树边全职相等,那就替换了个寂寞~。于是我们需要维护严格次大,如果没有次大那就是没有,一定要保证严格性

#include<bits/stdc++.h>
using namespace std;
inline char nc(){
    static char buf[100000],*p1=buf,*p2=buf;
    return p1==p2&&(p2=(p1=buf)+fread(buf,1,100000,stdin),p1==p2)?EOF:*p1++;
}
inline int rd(){
	int register data=0;static char ch=0;ch=nc();
	while(!isdigit(ch))ch=nc();
	while(isdigit(ch))data=(data<<1)+(data<<3)+(ch^48),ch=nc();
	return data;
}
const int N=1e5+1,M=3e5+1,inf=1e9;
int cnt,first[N],n,m,fa[N],dep[N],fir[N][18],sec[N][18],f[N][18],mnm;
long long sum;
bool vis[M];
struct edge{int v,w,nxt;}e[M<<1];
struct Edge{int u,v,w;}E[M];
inline int find(int x){return fa[x]==x?x:fa[x]=find(fa[x]);}
inline bool cmp(Edge x,Edge y){return x.w<y.w;}
inline void add(int u,int v,int w){e[++cnt]=(edge){v,w,first[u]},first[u]=cnt;}
inline void dfs(int u){
	for(int register i=1;(1<<i)<=dep[u];++i){
		f[u][i]=f[f[u][i-1]][i-1],fir[u][i]=max(fir[f[u][i-1]][i-1],fir[u][i-1]);
		if(fir[f[u][i-1]][i-1]!=fir[u][i-1])sec[u][i]=min(fir[f[u][i-1]][i-1],fir[u][i-1]);
		sec[u][i]=max(sec[u][i],max(sec[f[u][i-1]][i-1],sec[u][i-1]));
	}
	for(int register v,i=first[u];i;i=e[i].nxt){
		v=e[i].v;
		if(dep[v])continue;
		dep[v]=dep[u]+1,fir[v][0]=e[i].w,f[v][0]=u,dfs(v);
	}
}
typedef pair<int,int> T;
inline T lca(int a,int b){
	if(dep[a]<dep[b])swap(a,b);
	int register gap=dep[a]-dep[b],_1=0,_2=0;
	for(int register i=0;(1<<i)<=gap;++i)
		if(gap&(1<<i)){
			if(_1!=fir[a][i])_2=max(_2,min(_1,fir[a][i]));
			_1=max(_1,fir[a][i]),_2=max(_2,sec[a][i]),a=f[a][i];
		}
	if(a==b)return make_pair(_1,_2);
	for(int register i=17;i>=0;--i)
		if(f[a][i]!=f[b][i]){
			if(_1!=fir[a][i])_2=max(_2,min(_1,fir[a][i]));
			_1=max(_1,fir[a][i]),_2=max(_2,sec[a][i]),a=f[a][i];
			if(_1!=fir[b][i])_2=max(_2,min(_1,fir[b][i]));
			_1=max(_1,fir[b][i]),_2=max(_2,sec[b][i]),b=f[b][i];
		}
	if(_1!=fir[a][0])_2=max(_2,min(_1,fir[a][0]));
	if(_1!=fir[b][0])_2=max(_2,min(_1,fir[b][0]));
	_1=max(_1,max(fir[a][0],fir[b][0])),_2=max(_2,max(sec[a][0],sec[b][0]));
	return make_pair(_1,_2);
}
signed main(){
	mnm=inf,n=rd(),m=rd();
	for(int register i=1;i<=m;++i)E[i].u=rd(),E[i].v=rd(),E[i].w=rd();
	sort(E+1,E+m+1,cmp);
	for(int register i=1;i<=n;++i)fa[i]=i;
	for(int register u,v,w,fu,fv,i=1;i<=m;++i){
		u=E[i].u,v=E[i].v,w=E[i].w,fu=find(u),fv=find(v);
		if(fu!=fv)sum+=w,vis[i]=1,fa[fu]=fv,add(u,v,w),add(v,u,w);
	}dep[1]=1,dfs(1);
	for(int register i=1;i<=m;++i){
		if(vis[i])continue;
		int register u=E[i].u,v=E[i].v,w=E[i].w;
		T register t=lca(u,v);
		if(w!=t.first)mnm=min(mnm,w-t.first);
		else mnm=min(mnm,w-t.second);
	}cout<<sum+mnm,exit(0);
}

upd:
本来可以进水谷第一页的(即使不加fread),万万没想到有一个人疯狂提交AC代码,强行把我挤出了第一页这是提交记录第二页

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

洛谷P4180 [BJWC2010]严格次小生成树 的相关文章

  • 怎么解决 接口请求 504 Gateway Time-out

    HTTP 504 Gateway Timeout 错误通常是由于网关或代理服务器无法在规定的时间内从上游服务器接收到响应而导致的 这可能是由于上游服务器过载或网络问题导致的 要解决此问题 xff0c 可以尝试以下步骤 xff1a 检查上游服
  • WSL无法使用npm

    报错信息 root 64 DESKTOP U2RC2DU npm bash mnt c Program Files nodejs npm bin sh M bad interpreter No such file or directory
  • HDU 3700 Line belt

    Line belt Time Limit 2000 1000 MS Java Others Memory Limit 32768 32768 K Java Others Total Submission s 3669 Accepted Su
  • Ubuntu中使用framebuffer的方法

    打开 etc initramfs tools modules文件 xff0c 在末尾加上 xff1a fbcon vesafb 打开 etc modprobe d blacklist framebuffer xff0c 找到 blackli
  • html5.超链接标签,图片标签

    lt a gt 超链接标签 a标签常用的属性 xff1a href 用于指定链接的资源 target 设置打开新资源的目标 Blank 在独立的窗口上打开新资源 self 在当前窗口打开新资源 file file协议 xff08 文件协议
  • ubuntu22.04 搭建 Pytorch环境

    关于电脑 第一步 安装anaconda 1 进入官网 链接 anaconda 2 下载linux的sh版 3 在对应位置输入 span class token function sh span 文件名 sh 4 选择 yes 5 选择no
  • opencv的ORB特征(slambook2 orb_cv.cpp代码详解)

    ORB特征提取与匹配 slambook2 ch7 orb cv cpp 1 头文件 span class token macro property span class token directive hash span span clas
  • Debian安装nodejs

    安装指定版本nodejs xff0c 以18 X版本为例 1 通过curl命令向系统中添加NodeSource存储库 curl sL https deb nodesource com setup 18 x bash xff08 如果提示 c
  • pip安装第三方库全攻略:普通安装、安装whl后缀文件、使用国内镜像安装

    简介 xff1a pip 是 Python 的包安装程序 其实 xff0c pip 就是 Python 标准库 xff08 The Python Standard Library xff09 中的一个包 xff0c 只是这个包比较特殊 xf
  • Python:处理cv2模块putText中文无法识别问题

    简介 xff1a 在cv2中 xff0c 目前putText函数中文是无法直接使用的 xff0c 需要进行一点的转换 解决办法为通过PIL模块重新封装一个函数 xff0c 直接调用 如图 xff1a 通过PIL模块改造 xff1a new

随机推荐

  • VLC播放电视直播rtmp流地址

    简介 xff1a RTMP是Real Time Messaging Protocol xff08 实时消息传输协议 xff09 的首字母缩写 该协议基于TCP xff0c 是一个协议族 xff0c 包括RTMP基本协议及RTMPT RTMP
  • Python:global的使用

    简介 xff1a 1 global是Python中的全局变量关键字 2 全局变量是编程术语中的一种 xff0c 源自于变量之分 3 变量分为局部与全局 xff0c 局部变量又可称之为内部变量 4 由某对象或某个函数所创建的变量通常都是局部变
  • Python:opencv画点、圆、线、多边形、矩形

    简介 xff1a 机器学习视觉方向一般都需要在图像中添加标注框 xff0c 标注框有着很大的用处 xff0c 特别是对图像中某些需要关注的特征起到圈定的效果 xff0c 方便对特征选择进行处理 相关攻略 xff1a 机器学习 xff1a 基
  • adb重启或关机手机命令

    简介 xff1a 在某些特殊场景中 xff0c 例如手机真机不在身边 xff0c 但已通过adb进行连接 xff0c 可以使用命令进行远程关机或者重启 相关攻略 xff1a adb xff1a 常用命令 adb xff1a win10系统下
  • docker:更换镜像源

    简介 xff1a 因为国内的网络访问问题 xff0c 为加快拉取镜像速度 xff0c 建议设置docker国内镜像源 相关攻略 xff1a win10 xff1a 安装docker和测试安装redis centos7 6 xff1a 安装d
  • 七大顶级Linux桌面比较

    1七大顶级Linux桌面 xff1a Unity 对于开源Linux平台来说 xff0c 如何选择就是首要解决的问题 通常Linux发行版都有默认的桌面成为你的首选 xff0c 但目前可供选择的桌面环境种类繁多 特别是Ubuntu系统一个平
  • Linux:安装go环境

    简介 xff1a Go xff08 又称 Golang xff09 是 Google 的 Robert Griesemer xff0c Rob Pike 及 Ken Thompson 开发的一种静态强类型 编译型语言 Go 语言语法与 C
  • docker应用:搭建私有云盘

    简介 xff1a NextCloud是一个开源的云存储解决方案 xff0c 可以在自己的服务器上搭建个人云存储系统 它提供了与市面上主流云存储服务 xff08 如Dropbox Google Drive xff09 相似的功能 xff0c
  • Flask+A-Frame:交互式全景图展示网站

    简介 xff1a 通过结合 Flask 轻量级 Web 框架与 A Frame 3D 和 VR 技术 xff0c 实现了一个可交互的全景图展示功能 xff0c 用户可以在浏览器中自由观看 旋转和缩放全景图片 项目的核心是使用 Flask 搭
  • OpenCV合成全景图

    简介 xff1a OpenCV 利用特征提取 特征匹配 齐次估计 图像配准和图像融合等技术 xff0c 将一系列图像合成为全景图 OpenCV 和 Pillow 是两个功能强大的 Python 图像处理库 xff0c 但它们在处理全景图拼接
  • BDD行为驱动开发+Python案例解析

    简介 xff1a BDD xff08 Behavior Driven Development xff0c 行为驱动开发 xff09 是一种敏捷软件开发方法 xff0c 它强调软件应该按照预期的行为来开发 BDD的核心理念是使用自然语言编写的
  • 操作系统迭代、Debian安装教程

    前言 最近在考虑公司生产环境操作系统的迭代问题 目前 xff0c 公司业务主要跑在CentOS7和8上面 xff0c 由于CentOS早已停止了7和8的支持 xff0c 新版的CentOS Stream也从RHEL的下游变成了上游 xff0
  • Debian修改DNS

    原文链接 Debian的DNS文件默认为 etc resolv conf 查看当前的DNS cat etc resolv conf 下图中画出的就是当前系统的DNS 如果想修改DNS的话 xff0c 可以直接vim 来修改文件 xff0c
  • 配置JupyterLab远程密码访问

    文章目录 部署环境配置步骤启动和连接访问启动连接访问 有些时候因为某些原因 xff08 如本地机器资源不足 数据不能离网等 xff09 xff0c 需要使用本地电脑连接远程服务器进行开发工作 xff0c 在这里记录下如何在远程Linux上配
  • linux查看 jre 安装目录

    近期对接平安银行项目 xff0c 要求放国密 jar包到jre目录 xff0c 网上也找了一些命令 xff0c 下面这个亲测有用 xff0c 特此记录一下 xff0c 我的系统版本是3 10 0 693 el7 x86 64 步骤 1 使用
  • Python选择网卡发包及接收数据包

    当一台计算机上有多个网卡时 xff0c 需要选择对应IP地址的网卡进行发送数据包或者接受数据包 1 选择网卡发包 xff08 应用scapy xff09 xff1a plface 61 conf route route 34 34 0 为对
  • php 使用 Excel/reader.php, 导入excel到数据库 ,解决The file is not readable。。

    今天小伙伴上传excel到服务器 并导入到数据库中 xff0c 可是文件一直出现 The file is not readable 是哪里的代码抛出的异常呢 xff1f 是Spreadsheet Excel Reader类里面 其中抛出异常
  • “The Language Support for Java server crashed“ 问题解决方案

    The Language Support for Java server crashed 问题解决方案 环境 xff1a Windowsvs code 1 356 14日最新发布的VSCodeJavaInstaller online win
  • (循环读取网易云缓存文件转mp3)

    循环读取网易云缓存文件转mp3 import java io DataInputStream import java io DataOutputStream import java io File import java io FileIn
  • 洛谷P4180 [BJWC2010]严格次小生成树

    传送门 之前写过一次 xff0c 但是理解不深刻 xff0c 复习之后有了更加细节的一些理解 好了进入正题 首先 xff0c 我们需要知道次小生成树一定是在最小生成树的邻集中 xff0c 即次小生成树与最小生成树只会有一条边的差别 所以我们