NOIP2023模拟2联测23-害怕

澪有个 n n n 个点 m m m 条边的无向图,每条边都有蓝白两种颜色中的一种,保证蓝色的边形成了这个图的一个生成树。

她希望给这些边赋上边权,保证边权是 1 ∼ m 1 \sim m 1m 的排列,使得蓝色的边是最小生成树。

希望这些边权形成的序列字典序最小,也就是先比较第一条边的边权,再比较第二条边的边权,依次类推。

n , m ≤ 5 × 1 0 5 n,m\le5\times10^5 n,m5×105


对于一个生成树是最小生成树,都有任意的非树边的边权都与其形成环的树边的边权大。

一种想法是:考虑按输入顺序贪心确定每条边权值,对于一条非树边,记 k k k 为与之形成环的未被确定权值的树边数量,给这 k k k 条边按顺序确定权值,再给这条非树边设权值;对于树边直接赋权值即可。(正确性显然)

这样做时间复杂度是 O ( n m ) O(nm) O(nm),考虑优化。注意到每次操作时被标记的树边是连续的,所以可以用并查集维护这个连通块深度最小的点,每次像树剖找 LCA 选最深的点往上跳到所在连通块的顶端,直到两个点属于一个连通块为止。由于用了并查集维护,每条边只会走一次,后面又排序,时间复杂度 O ( n log ⁡ n ) O(n\log n) O(nlogn)

具体实现看代码

#include<bits/stdc++.h>
using namespace std;
const int N=5e5+1;
int n,m,f[N],val[N],p[N],ans[N],cnt1;
int head[N],nxt[N<<1],to[N<<1],w[N<<1],cnt;
int dep[N],fa[N],sz[N],son[N],top[N];
struct node
{int u,v,id,type;
}a[N];
void add(int u,int v,int W)
{to[++cnt]=v;w[cnt]=W;nxt[cnt]=head[u];head[u]=cnt;
}
void dfs(int u,int f)
{fa[u]=f;dep[u]=dep[f]+1;for(int i=head[u];i;i=nxt[i]){if(to[i]!=f){val[to[i]]=w[i];dfs(to[i],u);}}
}
int find(int x)
{return x==f[x]?x:f[x]=find(f[x]);
}
int main()
{scanf("%d%d",&n,&m);for(int i=1;i<=m;i++){scanf("%d%d%d",&a[i].u,&a[i].v,&a[i].type);if(a[i].type) add(a[i].u,a[i].v,i),add(a[i].v,a[i].u,i);}for(int i=1;i<=n;i++) f[i]=i;dfs(1,0);for(int i=1;i<=m;i++){int x=a[i].u,y=a[i].v,cnt=0;while(find(x)!=find(y)){if(dep[find(x)]<dep[find(y)]) swap(x,y);x=find(x);f[x]=find(fa[x]);p[++cnt]=val[x];}sort(p+1,p+1+cnt);for(int j=1;j<=cnt;j++) ans[p[j]]=++cnt1;if(a[i].type==0) ans[i]=++cnt1;}for(int i=1;i<=m;i++) printf("%d ",ans[i]);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/117875.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JAVA电商平台免费搭建 B2B2C商城系统 多用户商城系统 直播带货 新零售商城 o2o商城 电子商务 拼团商城 分销商城

涉及平台 平台管理、商家端&#xff08;PC端、手机端&#xff09;、买家平台&#xff08;H5/公众号、小程序、APP端&#xff08;IOS/Android&#xff09;、微服务平台&#xff08;业务服务&#xff09; 2. 核心架构 Spring Cloud、Spring Boot、Mybatis、Redis …

《红蓝攻防对抗实战》三.内网探测协议出网之HTTP/HTTPS协议探测出网

目录 一. 在 Windows 操作系统中探测 HTTP/HTTPS 出网 1. Bitsadmin 命令 2.Certuil 命令 2.Linux系统探测HTTP/HTTPS出网 1.Curl命令 2.Wget命令 对目标服务器探测 HTTP/HTTPS 是否出网时&#xff0c;要根据目标系统类型执行命令&#xff0c;不同类型的操作系统使用的探…

接口调优:从2s到200ms的心路历程分享

hello&#xff0c;大家好&#xff0c;我是灰小猿&#xff01; 平常在开发过程中&#xff0c;时常会遇到一些复杂查询或复杂业务&#xff0c;导致接口出现性能问题&#xff0c;基本上每一个程序猿在工作中都离不开对接口性能的调优&#xff0c; 今天我就在这里记录一下最近在实…

angular2+ 集成系统利用服务作为模块通信中间件

模块间通信的话angular2可以使用Input() 和 Output()进行父子组件间通信 例如 父组件html <app-input-output [item]"currentItem" (deleteRequest)"crossOffItem($event)"> </app-input-output>子组件ts export class ItemDetailComponent…

【IDEA查看一个jar包的依赖】

首先install,打jar包 重新创建一个项目 选中刚才的jar包 在这个包下就能看到jar包的依赖了

ES SearchAPI----Query DSL语言

文章目录 Getting Startedmatch_all查询全部sort排序from\size分页_source指定字段 match匹配查询match_phrase短语匹配multi_match多字段匹配range范围查询bool复合查询must必须匹配&#xff0c;可贡献得分must_not必须不匹配&#xff0c;可贡献得分should可有可无&#xff0c…

AnkiPDF Guru软件评测:打开全新学习方式的大门

在当今信息爆炸的时代&#xff0c;如何高效学习和记忆成为了每个人关注的焦点。AnkiPDF Guru软件作为结合了Anki和PDF的学习利器&#xff0c;向我们展示了一种全新的学习方式。本文将以软件的实用性和使用场景为切入点&#xff0c;从专业的角度客观分析和评测该软件&#xff0c…

VB.NET 中使用SqlConnection类连接到Microsoft SQL Server数据库的详细步骤

目录 前言: 过程: 1.建立SqlConnection连接 2.打开SqlConnection连接 3.关闭SqlConnection连接 4.执行SqlCommand命令 5.传递参数 总结: 前言: VB.NET的SqlConnection是一个用于连接到SQL Server数据库的类。在VB.NET中&#xff0c;SqlConnection是一个很重要的类&…

听GPT 讲Rust源代码--library/std(1)

std git:(master) ✗ tree.├── Cargo.toml├── benches│ ├── hash│ │ ├── map.rs│ │ ├── mod.rs│ │ └── set_ops.rs│ └── lib.rs├── build.rs├── src│ ├── alloc.rs│ ├── ascii.rs│ ├── backtrace│ │…

Mysql主从集群同步延迟问题怎么解决

主从复制 复制过程分为几个步骤&#xff1a; 主库的更新事件(update、insert、delete)被写到binlog 从库发起连接&#xff0c;连接到主库。 此时主库创建一个 binlog dump thread&#xff0c;把 binlog 的内容发送到从库。 从库启动之后&#xff0c;创建一个 I/O 线程&#xff…

TensorFlow和Pytorch两种机器学习框架的比较及优缺点

TensorFlow是一个开源的机器学习框架&#xff0c;由Google开发并发布&#xff0c;它被用来构建各种类型的机器学习模型&#xff0c;例如图像识别、语音识别、自然语言处理等。TensorFlow主要有以下几个基本概念&#xff1a; Tensor&#xff1a;TensorFlow中最基本的数据结构&am…

Pillow库(PIL)入门教程

Pillow库&#xff0c;PIL的升级版&#xff0c;一个免费开源的Python图像处理库。 Pillow 库&#xff08;有时也称 PIL 库&#xff09; 是 Python 图像处理的基础库&#xff0c;它是一个免费开源的第三方库&#xff0c;由一群 Python 社区志愿者使用 Python 语言开发而成&#…

创建Secret(手动)

和创建其他类型的 API 对象&#xff08;Pod、Deployment、StatefulSet、ConfigMap 等&#xff09;一样&#xff0c;您也可以先在 yaml 文件中定义好 Secret&#xff0c;然后通过 kubectl apply -f 命令创建。此时&#xff0c;您可以通过如下两种方式在 yaml 文件中定义 Secret&…

数字化营销如何推动企业营收增长?数字化营销要点有哪些?

在数字化席卷而来的时代&#xff0c;企业若想在激烈的市场竞争中脱颖而出&#xff0c;就得紧跟潮流&#xff0c;运用数字化营销手段更快、更准地触达目标客户&#xff0c;从而帮助企业更好地解读客户需求&#xff0c;捕捉痛点&#xff0c;实现精细化营销闭环。 数字化营销如何让…

经典卷积神经网络 - GoogLeNet

GoogLeNet是google推出的基于Inception模块的深度神经网络模型&#xff0c;在2014年的ImageNet竞赛中夺得了冠军&#xff0c;在随后的两年中一直在改进&#xff0c;形成了Inception V2、Inception V3、Inception V4等版本。 Inception块 4个路径从不同层面抽取信息&#xff0…

java版opencv之Javacv各种场景使用案例

文章目录 1.关于Javacv~~2. [官网下载最新OpenCV4.8](https://opencv.org/releases/)&#xff0c;并解压~~ *不一定要安装opencv*~~3. 将opencv的jar包及动态库dll文件引入项目~~4.pom引入javacv库5.测试5.1 图片美颜5.2 图片人脸检测5.3 提取视频中的语音5.4 音视频剪辑5.5 录…

python关于当前时间戳的获取及时间运算

日期和时间在计算机编程中是非常重要的概念&#xff0c;特别是在处理数据、日志记录、计划任务等方面。Python作为一门功能强大的编程语言&#xff0c;提供了丰富的库和内置函数&#xff0c;使得对日期和时间的操作变得简单而高效。本文将介绍一些常见的Python日期时间操作&…

shell脚本实战案例--系统服务脚本

目录 1、源码编译安装nginx 2、分别编写基于RHEL6和RHEL7的脚本。 2.1 RHEL6的nginx系统服务脚本 2.2 RHEL7的nginx系统服务脚本 1、源码编译安装nginx 1.首先关闭防火墙和selinux [rootnode13 ~]# systemctl stop firewalld [rootnode13 ~]# setenforce 0 2.准备环境&…

阿里云核心产品list

计算&#xff1a; 01函数计算&#xff08;Function Compute&#xff09;全托管serverless计算服务&#xff0c;不需要管理服务器等基础设施&#xff0c;只需要编写代码并上传。 02云服务器&#xff08;Elastic Compute Service&#xff09;云计算服务 03GPU云服务&#xff08;G…

java类的动态加载

java类的动态加载 java动态加载的机制&#xff1a; ClassLoader->SecureClassloader–>URLClassLoader–>AppClassLoader loadClass–>findClass(重写方法)–>defineClass(从字节码加载类) 初始化的时候会加载静态代码块 实例化的时候会加载构造代码块、无参构…