NOIP2023模拟2联测23 害怕

2023-10-25 19:01
文章标签 模拟 23 联测 害怕 noip2023

本文主要是介绍NOIP2023模拟2联测23 害怕,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目大意

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

你要给这些边赋上边权,要求边权是 1 ∼ m 1\sim m 1m的序列,使得蓝色的边是最小生成树。

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

1 ≤ n , m ≤ 5 × 1 0 5 , m ≥ n − 1 1\leq n,m\leq 5\times 10^5,m\geq n-1 1n,m5×105,mn1


题解

一个图的一棵树是最小生成树,当且仅当任意的非树边的边权都比与其形成环的树边大。

要让字典序最小,也就是要在蓝边形成最小生成树的前提下,让编号小的边尽量小。

我们按编号从小到大枚举边:

  • 如果是树边,且该边没有被赋值,则直接将其赋值
  • 如果是非树边,则将与其形成环的树边按编号从小到大赋值,再给这条非树边赋值

求与非树边形成环的树边,其实就是求非树边的两个点在树边上的路径。那么, 给与非树边形成环的树边其实就是在树上一边求 l c a lca lca一边给边赋值。

注意赋值是从小到大赋值,这样才能保证字典序最小。

在赋值的时候,每赋值完一条树边,我们可以用并查集来将树边上的两个点并起来,每次向上跳时只要到当前所在的并查集的编号最小的点,然后给这个点到父亲的边赋值即可。

但是,这样的话,它们有可能跳到 l c a lca lca上面的点。但这其实不影响,因为当两个点跳到同一个位置时就不会再跳了(也就是第一次跳到 l c a lca lca l c a lca lca的祖先时就不会再跳了),所以就不会对 l c a lca lca上面的边赋值。

因为用了并查集,所以我们可以暴力跳,每条边最多只会被跳一次,时间复杂度平摊下来是 O ( n ) O(n) O(n)的。在将树边按编号从小到大赋值时要对树边排序,总时间复杂度是 O ( n log ⁡ n ) O(n\log n) O(nlogn)的。

所以,总时间复杂度为 O ( n log ⁡ n ) O(n\log n) O(nlogn)

code

#include<bits/stdc++.h>
using namespace std;
const int N=500000;
int n,m,now=0,tot=0,d[2*N+5],l[2*N+5],r[N+5],id[2*N+5];
int fa[N+5],dep[N+5],tf[N+5],dn[N+5],up[N+5],ans[N+5];
struct node{int x,y,z;
}w[N+5];
void add(int xx,int yy,int i){l[++tot]=r[xx];d[tot]=yy;r[xx]=tot;id[tot]=i;
}
void dfs(int u,int f){fa[u]=f;dep[u]=dep[f]+1;tf[u]=u;for(int i=r[u];i;i=l[i]){if(d[i]==f) continue;dn[id[i]]=d[i];up[d[i]]=id[i];dfs(d[i],u);}
}
int find(int ff){if(ff!=tf[ff]) tf[ff]=find(tf[ff]);return tf[ff];
}
void pt(int x,int y){vector<int>v;x=find(x);y=find(y);while(x!=y){if(dep[x]<dep[y]) swap(x,y);v.push_back(up[x]);tf[x]=find(fa[x]);x=tf[x];}sort(v.begin(),v.end());for(int i=0;i<v.size();i++){ans[v[i]]=++now;}
}
int main()
{scanf("%d%d",&n,&m);for(int i=1,x,y,z;i<=m;i++){scanf("%d%d%d",&x,&y,&z);w[i]=(node){x,y,z};if(z){add(x,y,i);add(y,x,i);}}dfs(1,0);for(int i=1;i<=m;i++){if(w[i].z){if(tf[dn[i]]==dn[i]){ans[i]=++now;tf[dn[i]]=find(fa[dn[i]]);}}else{pt(w[i].x,w[i].y);ans[i]=++now;}}for(int i=1;i<=m;i++){printf("%d ",ans[i]);}return 0;
}

这篇关于NOIP2023模拟2联测23 害怕的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/284578

相关文章

基于 Java 实现的智能客服聊天工具模拟场景

服务端代码 import java.io.BufferedReader;import java.io.IOException;import java.io.InputStreamReader;import java.io.PrintWriter;import java.net.ServerSocket;import java.net.Socket;public class Serv

人工智能在数字病理切片虚拟染色以及染色标准化领域的研究进展|顶刊速递·24-06-23

小罗碎碎念 本期推文主题:人工智能在数字病理切片虚拟染色以及染色标准化领域的研究进展 这一期的推文是我发自内心觉得为数不多,特别宝贵的一篇推文,原因很简单——可参考的文献相对较少&方向非常具有研究意义&现在不卷。 数字病理方向的老师/同学应该清楚,不同中心提供的切片,染色方案是存在差异的,并且还存在各种质量问题,所以我们在数据预处理的时候,通常会先对切片的质量执行一遍筛选,然后再进行染

23.并发

目录 一、一些概念二、进程和线程2.1 概念2.2 多线程导致的问题2.3 使用spawn创建新线程2.4 线程与move闭包 三、消息传递3.1 概念3.2 创建通道3.3 示例3.4 其它测试 四、共享状态并发4.1 互斥器4.2 Mutex的API4.3 多线程共享Mutex1)在多线程之间共享值;2)多线程和多所有权3) 原子引用计数4)RefCell/Rc与 Mutex/Arc的相

价格减免(Lc2288)——模拟

句子 是由若干个单词组成的字符串,单词之间用单个空格分隔,其中每个单词可以包含数字、小写字母、和美元符号 '$' 。如果单词的形式为美元符号后跟着一个非负实数,那么这个单词就表示一个 价格 。 例如 "$100"、"$23" 和 "$6" 表示价格,而 "100"、"$" 和 "$1e5 不是。 给你一个字符串 sentence 表示一个句子和一个整数 discount 。对于每个表示价格的单

24-6-23-读书笔记(七)-《文稿拾零》豪尔赫·路易斯·博尔赫斯(第三辑)

文章目录 《文稿拾零》阅读笔记记录总结 《文稿拾零》   《文稿拾零》超厚的一本书(570+),看得时间比较长,这本书是作者零散时间写的一些关于文学性质的笔记,读起来还是比较无趣的,非常零散,虽然有很多有趣的观点,但连不起来,不像毛姆的读书笔记,简单记录一下了。 阅读笔记记录 P3 桑德堡身上有一种疲倦的忧伤,一种平原傍晚时的忧伤,泥沙浊流的忧伤,无用却又精确回忆的忧伤,一个

模拟木马程序自动运行:Linux下的隐蔽攻击技术

模拟木马程序自动运行:Linux下的隐蔽攻击技术 在网络安全领域,木马程序是一种常见的恶意软件,它能够悄无声息地在受害者的系统中建立后门,为攻击者提供远程访问权限。本文将探讨攻击者如何在Linux系统中模拟木马程序的自动运行,以及他们可能使用的技术手段。 木马自动运行的常见方法 攻击者通常会使用以下几种方法来确保木马在Linux系统中自动运行: 计划任务(Crontab): 攻击者可以通

2023-2024 学年第二学期小学数学六年级期末质量检测模拟(制作:王胤皓)(90分钟)

word效果预览: 一、我会填 1. 1.\hspace{0.5em} 1. 一个多位数,亿位上是次小的素数,千位上是最小的质数的立方,十万位是 10 10 10 和 15 15 15 的最大公约数,万位是最小的合数,十位上的数既不是质数也不是合数,这个数是 ( \hspace{4em} ),约等于 ( \hspace{1em} ) 万 2. 2.\hspace{0.5em} 2.

java实训 | 低配版模拟火车订票系统

代码:  import javax.swing.*;import java.awt.*;import java.awt.event.ActionEvent;import java.util.ArrayList;import java.util.List;public class TrainBookingSystem {private JFrame frame;private JPanel

LeetCode 每日一题 2024/6/17-2024/6/23

记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步 目录 6/17 522. 最长特殊序列 II6/18 2288. 价格减免6/19 2713. 矩阵中严格递增的单元格数6/20 2748. 美丽下标对的数目6/21 LCP 61. 气温变化趋势6/22 2663. 字典序最小的美丽字符串6/23 520. 检测大写字母 6/1

phpmailer 邮件模拟注册验正

下载phpmailer类 我本次的实验用的是版本 5.2.9 下载后解压提取文件class.smtp.php class.phpmailer.php PHPMailerAutoload.php 放在phpmailer目录里 1.链接数据库 conn.php   $conn=mysql_connect("localhost","root","");    if(!$conn){