【蓝桥杯 LCA 差分】 砍树

在这里插入图片描述


题目分析:

这道题还是比较裸的一道书上差分的题目了
对于每一对标记点(x,y)
他们之间的路径就是 x − > L C A ( x , y ) − > y x->LCA(x,y)->y x>LCA(x,y)>y
这条路径上的每一条边都要经过。

那么对于一条边,什么时候砍掉这条边的时候,这几对点互相到达不了呢?
那就是这条边是这m条路径(一共m对点,每一对点都有一条路径)的公共边
也就是说这条边被经过了m次

因此,对于每一条边,我们用一个数组记录这条边被经过了几次
最后经过次数为m的边就是可以砍掉的边,最后取一个max即可

那么我们如何累加边经过的次数呢
借鉴数列差分的思想,我们利用树上差分去实现
对于一堆点 ( x , y ) (x,y) (x,y),我们令 s [ x ] + + , s [ y ] + + , s [ L c a ( x , y ) ] − = 2 s[x]++,s[y]++,s[Lca(x,y)]-=2 s[x]++,s[y]++,s[Lca(x,y)]=2
而后在树上做一遍前缀和即可


Code

#include<bits/stdc++.h>
using namespace std;

const int N = 1e5+100;

int fa[N][30];
int n,m;
struct Node{
	int y,Next,id;
}e[2*N];
int len , Linkk[N];
int s[N];
int d[N];
           
void Insert(int x,int y,int id){
	e[++len] = (Node){y,Linkk[x],id};
	Linkk[x] = len;
}

void Dfs(int x,int faa,int dd){
	d[x] = dd;
	for (int i = Linkk[x]; i; i = e[i].Next){
		int y = e[i].y;
		if (y == faa) continue;
		fa[y][0] = x;
		Dfs(y,x,dd+1);
	}
}

void Pre(){
	for (int j = 1; (1 << j) < n; j++)
	  for (int i = 1; i <= n; i++)
	    if (fa[i][j-1] == -1) fa[i][j] = -1;
	    else fa[i][j] = fa[fa[i][j-1]][j-1];
}

int Lca(int x,int y){
	if (d[x] > d[y]) swap(x,y);
	for (int i = 0,dd = d[y]-d[x];dd; dd>>=1,i++)
	  if (dd&1) y = fa[y][i];
	if (x == y) return x;
	for (int i = 29; i >= 0; i--)
	  if (fa[x][i] != fa[y][i]) x = fa[x][i] , y =fa[y][i];
	return fa[x][0];
}

void Plus(int x,int y){
	s[x]++ , s[y]++ , s[Lca(x,y)]-=2;
}

void Dfss(int x,int faa){
	for (int i = Linkk[x]; i; i = e[i].Next){
		int y = e[i].y;
		if (y == faa) continue;
		Dfss(y,x);
		s[x]+=s[y];
	}
}

int Max = -1;
void dfsM(int x,int faa){
	for (int i = Linkk[x]; i; i = e[i].Next){
		int y = e[i].y; 
		if (y == faa) continue;
		if (s[y] == m) Max = max(Max,e[i].id);
		dfsM(y,x);
	}
}

int main(){
	scanf("%d %d",&n,&m);
	for (int i = 1,x,y; i < n; i++)
	  scanf("%d %d",&x,&y) , Insert(x,y,i) , Insert(y,x,i);
	Dfs(1,0,0); fa[1][0] = -1; Pre();
	for (int i = 1 , x,y; i <= m; i++)
	  scanf("%d %d",&x,&y) , Plus(x,y);
	Dfss(1,0);
	dfsM(1,0);
	cout<<Max;
	return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【推荐系统】MMOE笔记 20231126

paper阅读 任务差异带来的固有冲突实际上会损害至少某些任务的预测&#xff0c;特别是当模型参数在所有任务之间广泛共享时。&#xff08;在说ESMM&#xff09; 共享底层参数可以减少过拟合风险&#xff0c;但是会遇到任务差异引起的优化冲突&#xff0c;因为所有任务都需要在…

Django二转Day02

http #1 http 是什么#2 http特点#3 请求协议详情 -请求首行---》请求方式&#xff0c;请求地址&#xff0c;请求协议版本 -请求头---》key:value形式 -referer&#xff1a;上一次访问的地址 -user-agenet&#xff1a;客户端类型 -name&#x…

JSP迭代标签之 forEach循环标签 基本使用讲解

好 之前我们讲完了 我们的条件动作标签 那么 我们来继续说 迭代标签 所谓迭代就是 将某个主体循环多次 也可以循环 集合 对象 map 这个标签叫 forEach items 就是 我们要循环的数据 注意 这里 操作的也是域对象中的值 begin 开始说 例如 i 0;i<x;i begin 就是开始数 当前…

1.Spring源码解析-ClassPathXmlApplicationContext

此类是读取spring的xml配置文件并解析。也是源码入口之一。 我们调试即将开始。 传递给父类设置值 经调试我们得到是给AbstractApplicationContext设置默认的应用上下文父级的值&#xff0c;很明显是空 给父类AbstractRefreshableConfigApplicationContext设置属性 刷新容器…

AMESim|学习记录

此文记录AMESim学习过程中的各种情况。 目录 01 王佳. AUV 浮力调节系统设计及控制策略研究[D]. 天津大学, 2017.01 王佳. AUV 浮力调节系统设计及控制策略研究[D]. 天津大学, 2017. 01 王佳. AUV 浮力调节系统设计及控制策略研究[D]. 天津大学, 2017. 开始步入正文 01 王佳.…

Open AI宫斗始末:董事会开除CEO再复职,这场闹剧终于结束了!

老哥们&#xff0c;作为一名在科技圈吃瓜前线的程序员&#xff0c;这几天open ai的瓜都吃到了吗&#xff1f;反转反转再反转&#xff0c;堪称职场版的《甄嬛传》&#xff01; 惊呆了&#xff0c;CEO被解雇又回归…… 在梳理open ai时间线之前&#xff0c;给大家先介绍一下这个…

C++基础 -9- 函数的默认参数

函数默认格式(图片代码段呈现) #include "iostream"using namespace std;void rlxy(int a100) {cout << a << endl; }int main() {rlxy();rlxy(99); }函数默认参数注意事项 函数的默认参数从左开始推导 错误写法 正确写法

029 - STM32学习笔记 - ADC(三) 独立模式单通道DMA采集

029 - STM32学习笔记 - 单通道DMA采集&#xff08;三&#xff09; 单通道ADC采集在上节中学习完了&#xff0c;这节在上节的内容基础上&#xff0c;学习单通道DMA采集。程序代码以上节的为基础&#xff0c;需要删除NVIC配置函数、中段服务子程序、R_ADC_Mode_Config()函数中使能…

UE 事件分发机制 day9

观察者模式原理 观察者模式通常有观察者与被观察者&#xff0c;当被观察者状态发生改变时&#xff0c;它会通知所有的被观察者对象&#xff0c;使他们能够及时做出响应&#xff0c;所以也被称作“发布-订阅模式”。总得来说就是你关注了一个主播&#xff0c;主播的状态改变会通…

西南科技大学C++程序设计实验二(类与对象一)

C++最大的特点就是面向对象,掌握它的几种基本性质还是好理解的,可以看我C++专栏的期末速成,希望对你们学习C++有帮助。 一、实验目的 1.理解简单类的定义、说明与使用 2.理解类中不同属性数据成员的访问特点 3.理解构造函数、析构函数的作用 重点:掌握类的定义与实现,…

成为AI产品经理——模型评估指标

目录 一、模型评估分类 1.在线评估 2.离线评估 二、离线模型评估 1.特征评估 ① 特征自身稳定性 ② 特征来源稳定性 ③ 特征成本 2.模型评估 ① 统计性评估 覆盖度 最大值、最小值 分布形态 ② 模型性能指标 分类问题 回归问题 ③ 模型的稳定性 模型评估指标分…

Java高级技术(反射:获取类)

一&#xff0c;认识反射 二&#xff0c; 反射第一步 三&#xff0c;案例

数据库的增删查改(CRUD)基础版

CRUD: create增加、retrieve查询、update更新、delete删除 注意一点&#xff1a;MySQL对大小写是不敏感的 目录 新增&#xff08;create&#xff09; 全列插入 指定列插入 多行插入 查询&#xff08;Retrieve&#xff09; 列查询 全列查询 指定列查询 表达式查询 …

【问题解决!】OSError: [WinError 1455] 页面文件太小,无法完成操作。Error loading “c:\Anaconda3\lib

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 问题描述问题原因二、解决方法 问题描述 在使用pytorch跑深度学习的时候报错OSError: [WinError 1455] 页面文件太小&#xff0c;无法完成操作。Error loading “c…

vivado产生报告阅读分析27

1、设计 QoR 汇总 命令行选项 -qor_summary 可用于为流程中每个步骤生成 QoR 汇总信息。该选项只能从 Tcl 控制台使用。该选项可按两种格式生成&#xff1a; 基于文本的报告或 JSON 格式。 要生成基于文本的格式 &#xff0c; 请运行以下命令 &#xff1a; report_des…

0005Java程序设计-ssm基于微信小程序的校园求职系统

文章目录 摘 要目 录系统设计开发环境 编程技术交流、源码分享、模板分享、网课分享 企鹅&#x1f427;裙&#xff1a;776871563 摘 要 随着我国经济迅速发展&#xff0c;人们对手机的需求越来越大&#xff0c;各种手机软件也都在被广泛应用&#xff0c;但是对于手机进行数据…

小白必知:AIGC 和 ChatGPT 的区别

原文 &#xff1a; https://openaigptguide.com/chatgpt-aigc-difference/ AIGC 和 ChatGPT 都是人工智能技术&#xff0c;但它们的功能和应用场景不同。 AIGC&#xff08;AI-GeneratedContent&#xff0c;人工智能自动生成内容&#xff09;是人工智能、计算机图形学和深度学…

dbvisual editor 显示中文乱码

打开如下的页面就可以选择中文相关的字体就可以正常显示中文了。

spring-boot对rabbitMQ的操作

一、安装rabbitMQ 1、直接使用docker拉取镜像 docker pull rabbitmq:3.82、启动容器 docker run \-e RABBITMQ_DEFAULT_USERadmin \-e RABBITMQ_DEFAULT_PASS123456 \-v mq-plugins:/plugins \--name rabbit01 \--hostname rabbit01 --restartalways \-p 15672:15672 \-p 5672:…