[NOIP2016]天天爱跑步

题目链接

虽然确实用 d f n 序计算贡献比递归调用好写也不饶,但谁让我是犟种呢 \sout{虽然确实用dfn序计算贡献比递归调用好写也不饶,但谁让我是犟种呢} 虽然确实用dfn序计算贡献比递归调用好写也不饶,但谁让我是犟种呢

题目大意就是说每个点 i i i有个观察员,会在 w i w_i wi时刻观察,有 m m m条路径,人沿路径跑,只有在 w i w_i wi那一时刻人刚好到那里才会让答案 + 1 +1 +1,问每个点的答案

思路:
也是学别人知道可以用 D S U o n T r e e DSU\ on\ Tree DSU on Tree做的,考虑对于一个点 x x x,哪些情况会对答案有贡献,必要条件显然得是,某一条路径的起点或者终点在以 x x x为根的子树里面,然后还有刚好在 w x w_x wx时刻跑到 x x x的限制.

我们分两种情况考虑:
1. 1. 1.起点在以 x x x为根的子树里面
2. 2. 2.终点在以 x x x为根的子树里面

对于情况一,可以看成是与 x x x深度差为 w x w_x wx的点
对于情况二,显然要满足 路径长度 − 深度差 = w x 路径长度-深度差 = w_x 路径长度深度差=wx
写成方程类似于 l e n − ( d e p y − d e p x ) = w x len-(dep_y-dep_x) = w_x len(depydepx)=wx
其中y是终点, l e n len len是路径长度

移项一下可以得到 l e n − d e p y = d e p x + w x len-dep_y=dep_x+w_x lendepy=depx+wx
左式和右式都只与自身有关.小trick来了,可以开两个桶解决,每次计算询问对应桶的值即可

一些细节:
路径会被计算两遍,如果是以x为起点和终点的 l c a lca lca的话,要去重,记录一下以x为 l c a lca lca的路径即可

最重要的是,以 x x x l c a lca lca的路径对上面的节点是没有贡献的,要删除它们

#include<bits/stdc++.h>
using namespace std;
using i64 = long long;
using i128 = __int128;const int maxn = 3e5+10;
const int base = 3e5+1;//偏移量,防止索引是负的
int n,m;
int w[maxn],ans[maxn],s[maxn],t[maxn],len[maxn];//len是路径长度
int f[maxn][25],sz[maxn],son[maxn],HH,l[maxn],dep[maxn];
int cnt0[maxn<<1],cnt1[maxn<<1];//桶,如果开map就可以不用偏移量了
vector<int>mark[maxn];//mark[i],以i为lca的路径
vector<int>g[maxn],ed[maxn],st[maxn];//树,以i为起点的路径st[i],以i为终点的路径ed[i]void dfs(int x,int fa){sz[x]=1;f[x][0]=fa;dep[x] = dep[fa]+1;for(int i = 1;i<25;++i) f[x][i] = f[f[x][i-1]][i-1];for(auto y:g[x]){if(y==fa) continue;dfs(y,x);sz[x]+=sz[y];if(sz[y]>sz[son[x]]) son[x]=y;}
}int lca(int x,int y){if(dep[x]<dep[y]) swap(x,y);for(int i = 24;i>=0;--i){if(dep[f[x][i]]>=dep[y]) x = f[x][i];}if(x==y) return x;for(int i = 24;i>=0;--i){if(f[x][i]!=f[y][i]){x = f[x][i];y = f[y][i];}}return f[x][0];
}void calc(int x,int fa,bool op,int root){if(op){for(auto p:st[x]){if(dep[l[p]]<=dep[root]) ++cnt0[dep[x]];}for(auto p:ed[x]){if(dep[l[p]]<=dep[root]) ++cnt1[len[p]-dep[x]+base];}}else{for(auto p:st[x]){if(dep[l[p]]<=dep[root]) --cnt0[dep[x]];}for(auto p:ed[x]){if(dep[l[p]]<=dep[root]) --cnt1[len[p]-dep[x]+base];}}for(auto y:g[x]){if(y==fa||y==HH) continue;calc(y,x,op,root);}
}void del(int x, bool flag) {for(auto p : mark[x]) {if(dep[s[p]] == dep[x] + w[x]) ans[x] --;//把重复计算的删掉if(flag) cnt0[dep[s[p]]] --, cnt1[len[p] - dep[t[p]] + base] --;//只有当x是重儿子时才删,因为若x是轻儿子在下面就会被清空了}
}void dsu(int x,int fa,bool op){for(auto y:g[x]){if(y==fa||y==son[x]) continue;dsu(y,x,0);}if(son[x]) dsu(son[x],x,1),HH=son[x];calc(x,fa,1,x);HH=0;ans[x] += cnt0[dep[x] + w[x]] + cnt1[w[x] - dep[x] + base];del(x,op);//把lca为x的路径贡献删掉,因为它不会对上面有贡献if(!op) calc(x,fa,0,x);
}signed main(){ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);cin>>n>>m;for(int i = 1;i<n;++i){int x,y;cin>>x>>y;g[x].emplace_back(y);g[y].emplace_back(x);}for(int i = 1;i<=n;++i) cin>>w[i];dfs(1,0);for(int i = 1;i<=m;++i){cin>>s[i]>>t[i];l[i] = lca(s[i],t[i]);//l[i]是lcalen[i] = dep[s[i]]+dep[t[i]]-2*dep[l[i]];mark[l[i]].emplace_back(i);ed[t[i]].emplace_back(i);st[s[i]].emplace_back(i);}dsu(1,0,0);for(int i = 1;i<=n;++i) cout<<ans[i]<<" ";cout<<"\n";return 0;
}

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

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

相关文章

spring揭秘24-springmvc02-5个重要组件

文章目录 【README】【1】HanderMapping-处理器映射容器【1.1】HanderMapping实现类【1.1.1】SimpleUrlHandlerMapping 【2】Controller&#xff08;二级控制器&#xff09;【2.1】AbstractController抽象控制器&#xff08;控制器基类&#xff09; 【3】ModelAndView(模型与视…

java入门基础(一篇搞懂)

​ 如果您觉得这篇文章对您有帮助的话 欢迎您分享给更多人哦 感谢大家的点赞收藏评论&#xff0c;感谢您的支持&#xff01;&#xff01;&#xff01; 首先给大家推荐比特博哥&#xff0c;java入门安装的JDk和IDEA社区版的安装视频 JDK安装与环境变量的配置 IDEA社区的安装与使…

帝国CMS系统开启https后,无法登陆后台的原因和解决方法

今天本地配置好了帝国CMS7.5&#xff0c;传去服务器后&#xff0c;使用http访问一切正常。但是当开启了https&#xff08;SSL&#xff09;后&#xff0c;后台竟然无法登陆进去了。 输入账号密码后&#xff0c;点击登陆&#xff0c;跳转到/e/admin/ecmsadmin.php就变成页面一片…

SpringBoot基础(三):Logback日志

SpringBoot基础系列文章 SpringBoot基础(一)&#xff1a;快速入门 SpringBoot基础(二)&#xff1a;配置文件详解 SpringBoot基础(三)&#xff1a;Logback日志 目录 一、日志依赖二、日志格式1、记录日志2、默认输出格式3、springboot默认日志配置 三、日志级别1、基础设置2、…

golang-基础知识(流程控制)

1 条件判断if和switch 所有的编程语言都有这个if&#xff0c;表示如果满足条件就做某事&#xff0c;不满足就做另一件事&#xff0c;go中的if判断和其它语言的区别主要有以下两点 1. go里面if条件判断不需要括号 2. go的条件判断语句中允许声明一个变量&#xff0c;这个变量…

FPGA-UART串口接收模块的理解

UART串口接收模块 背景 在之前就有写过关于串口模块的文章——《串口RS232的学习》。工作后很多项目都会用到串口模块&#xff0c;又来重新理解一下FPGA串口接收的代码思路。 关于串口相关的参数&#xff0c;以及在文章《串口RS232的学习》中已有详细的描述&#xff0c;这里就…

单调队列与单调栈<2>——单调栈

单调栈的定义 单调递增栈 栈中元素从栈底到栈顶是递增的。 单调递减栈 栈中元素从栈底到栈顶是递减的。 单调栈的核心内容 我们从左到右遍历元素&#xff0c;构造单调栈&#xff08;从栈顶到栈底递增或减&#xff09;&#xff1a;在 i 从左往右遍历的过程中&#xff0c;我…

手写堆排序

手写堆排序 摘要&#xff1a;本文记录使用go语言实现堆排序 堆的构建 堆性质&#xff1a; 对于每个小堆&#xff0c;父节点与两个子节点比较&#xff0c;父节点比左子节点大&#xff0c;也比右子节点大。 有五个数&#xff1a; 1,2,3,4,5 分别进行入栈。过程如下 (1) 堆为…

(作业)第三期书生·浦语大模型实战营(十一卷王场)--书生入门岛通关第3关Git 基础知识

任务编号 任务名称 任务描述 1 破冰活动 提交一份自我介绍。 2 实践项目 创建并提交一个项目。 破冰活动 提交一份自我介绍。 每位参与者提交一份自我介绍。 提交地址&#xff1a;https://github.com/InternLM/Tutorial 的 camp3 分支&#xff5e; 安装并设置git 克隆仓库并…

[深度学习][python]yolov11+deepsort+pyqt5实现目标追踪

【算法介绍】 YOLOv11、DeepSORT和PyQt5的组合为实现高效目标追踪提供了一个强大的解决方案。 YOLOv11是YOLO系列的最新版本&#xff0c;它在保持高检测速度的同时&#xff0c;通过改进网络结构、优化损失函数等方式&#xff0c;提高了检测精度&#xff0c;能够同时处理多个尺…

CSS选择器的全面解析与实战应用

CSS选择器的全面解析与实战应用 一、基本选择器1.1 通配符选择器&#xff08;*&#xff09;2.标签选择器&#xff08;div&#xff09;1.3 类名选择器&#xff08;.class&#xff09;4. id选择器&#xff08;#id&#xff09; 二、 属性选择器&#xff08;attr&#xff09;三、伪…

欧几里得算法--(密码学基础)

根基&#xff1a;gcd(a,b)gcd(b,a mod b) 先举个例子吧&#xff0c;gcd(16,6)gcd(6,4)gcd(4,2)gcd(2,0)2 学习这个定理的时候我想了几个问题. 第一个问题&#xff1a;为什么求出的就一定是他们两个数的公约数&#xff1f; 这个问题很简单我们只需要通过几何来计较即可&#x…

Electron 使⽤ electron-builder 打包应用

electron有几种打包方式&#xff0c;我使用的是electron-builder。虽然下载依赖的时候让我暴躁&#xff0c;使用起来也很繁琐&#xff0c;但是它能进行很多自定义&#xff0c;打包完成后的体积也要小一些。 安装electron-builder&#xff1a; npm install electron-builder -…

python基础语法2

文章目录 1.顺序语句2.条件语句2.1 语法格式 3.缩进与代码块4.空语句 pass5.循环语句5.1 while循环5.2 for循环 5.3 continue与break 1.顺序语句 默认情况下&#xff0c;python的代码都是按照从上到下的顺序依次执行的。 print(hello ) print(world)结果一定是hello world。写…

【AIGC】ChatGPT提示词解析:如何打造个人IP、CSDN爆款技术文案与高效教案设计

博客主页&#xff1a; [小ᶻZ࿆] 本文专栏: AIGC | ChatGPT 文章目录 &#x1f4af;前言&#x1f4af;打造个人IP爆款文案提示词使用方法 &#x1f4af;CSDN爆款技术文案提示词使用方法 &#x1f4af;高效教案设计提示词使用方法 &#x1f4af;小结 &#x1f4af;前言 在这…

zookeeper 服务搭建(集群)

准备3台虚拟机&#xff0c;ip分别是&#xff1a; 192.168.10.75 192.168.10.76 192.168.10.77 准备3个节点 mkdir /usr/local/cluster cd /usr/local/cluster git clone https://gitee.com/starplatinum111/apache-zookeeper-3.5.9-bin.git 重命名文件夹 mv apache-zookeeper…

【学习笔记】手写一个简单的 Spring IOC

目录 一、什么是 Spring IOC&#xff1f; 二、IOC 的作用 1. IOC 怎么知道要创建哪些对象呢&#xff1f; 2. 创建出来的对象放在哪儿&#xff1f; 3. 创建出来的对象如果有属性&#xff0c;如何给属性赋值&#xff1f; 三、实现步骤 1. 创建自定义注解 2. 创建 IOC 容器…

软件设计师——计算机网络

&#x1f4d4;个人主页&#x1f4da;&#xff1a;秋邱-CSDN博客☀️专属专栏✨&#xff1a;软考——软件设计师&#x1f3c5;往期回顾&#x1f3c6;&#xff1a;软件设计师——操作系统&#x1f31f;其他专栏&#x1f31f;&#xff1a;C语言_秋邱 一、OSI/ RM七层模型(⭐⭐⭐)…

Windows安装Vim,并在PowerShell中直接使用vim

大家好啊&#xff0c;我是豆小匠。 这期介绍下怎么在windows的PowerShell上使用vim&#xff0c;方便在命令行里修改配置文件等。 先上效果图&#xff1a; 1、下载Vim GitHub传送门&#xff1a;https://github.com/vim/vim-win32-installer/releases 选择win-64的版本下载即可&…

HIKVISION 海康威视对讲服务配置平台弱口令

漏洞描述 杭州海康威视系统技术有限公司对讲服务配置平台存在弱口令 漏洞复现 FOFA "document.write(TITLE_SYSTEM);" POC admin #账号 12345 #密码 登录成功