2021牛客OI赛前集训营-提高组(第四场) T3快速访问
2021牛客OI赛前集训营-提高组(第四场)
题目大意
有一棵n+1n+1n+1个节点的树,根节点为0。给你一个kkk,定义集合Si={j∈Z∣max(1,i−k)≤j<i}∪{0}S_i=\{j\in Z|\max(1,i-k)\leq j<i\}\cup\{0\}Si={j∈Z∣max(1,i−k)≤j<i}∪{0}。
Ai=∑j∈Sidis(i,j)2A_i=\sum\limits_{j\in S_i}dis(i,j)^2Ai=j∈Si∑dis(i,j)2,dis(i,j)dis(i,j)dis(i,j)指iii到jjj在树上的距离。求A1,A2,…,AnA_1,A_2,\dots,A_nA1,A2,…,An分别是多少。
题解
令aia_iai表示iii在树上的深度,注意根节点的深度为1。
那么dis(i,j)2=(ai+aj−2alca)2=ai2+aj2+2aiaj−4alcaai−4alcaaj+4alca2dis(i,j)^2=(a_i+a_j-2a_{lca})^2=a_i^2+a_j^2+2a_ia_j-4a_{lca}a_i-4a_{lca}a_j+4a_{lca}^2dis(i,j)2=(ai+aj−2alca)2=ai2+aj2+2aiaj−4alcaai−4alcaaj+4alca2
我们可以枚举iii,用树链剖分来维护jjj的值。
对于ai2a_i^2ai2,可以直接得出。
对于aj2a_j^2aj2,将所有在SiS_iSi中的jjj求前缀和即可。
对于2aiaj2a_ia_j2aiaj,对aja_jaj求前缀和,再乘上2ai2a_i2ai。
对于4alcaai4a_{lca}a_i4alcaai,对每个SiS_iSi中的jjj,都将jjj到根节点的路径上的点加1,然后查询iii到根节点的路径上的对应值的和,再乘上4ai4a_i4ai即可。
对于4alcaaj4a_{lca}a_j4alcaaj,对每个SiS_iSi中的jjj,都将jjj到根节点的路径上的点加aja_jaj,然后查询iii到根节点的路径上的对应值的和,再乘上444即可。
对于4alca24a_{lca}^24alca2,对每个SiS_iSi中的jjj,都将jjj到根节点的路径上的点加ak∗2−1a_k*2-1ak∗2−1(kkk表示当前节点),然后查询iii到根节点的路径上的对应值的和,因为x2=1+3+5+⋯+(x∗2−1)x^2=1+3+5+\cdots+(x*2-1)x2=1+3+5+⋯+(x∗2−1),所以这样求出的就是alca2a_{lca}^2alca2,然后乘444即可。
对于jjj进入集合或离开集合,在jjj到根节点的路径上进行区间修改即可。
为什么根节点的深度为1而不为0呢?因为只有根节点的深度为1,那么每个点到根节点的路径的长度才能等于这个点的深度,这样才能更好地实现。
时间复杂度为O(nlog2n)O(n\log^2 n)O(nlog2n)。
code
#include<bits/stdc++.h>
#define lc k<<1
#define rc k<<1|1
using namespace std;
int n,k,x,y,tot=0,d[500005],l[500005],r[500005],dep[500005],fa[500005],siz[500005],son[500005];
int tp[200005],s[200005],re[200005];
long long ans,hv1[800005],hv2[800005],mx1[800005],mx2[800005],mx3[800005],ly1[800005],ly2[800005],ly3[800005];
void add(int xx,int yy){l[++tot]=r[xx];d[tot]=yy;r[xx]=tot;
}
void dfs1(int u,int f){fa[u]=f;dep[u]=dep[f]+1;siz[u]=1;for(int i=r[u];i;i=l[i]){if(d[i]==f) continue;dfs1(d[i],u);siz[u]+=siz[d[i]];if(siz[d[i]]>siz[son[u]]) son[u]=d[i];}
}
void dfs2(int u,int f){if(son[u]){tp[son[u]]=tp[u];s[son[u]]=++s[0];re[s[0]]=son[u];dfs2(son[u],u);}for(int i=r[u];i;i=l[i]){if(d[i]==f||d[i]==son[u]) continue;tp[d[i]]=d[i];s[d[i]]=++s[0];re[s[0]]=d[i];dfs2(d[i],u);}
}
void build(int k,int l,int r){if(l==r){hv1[k]=2ll*dep[re[l]]-1;hv2[k]=1ll;return;}int mid=l+r>>1;build(lc,l,mid);build(rc,mid+1,r);hv1[k]=hv1[lc]+hv1[rc];hv2[k]=hv2[lc]+hv2[rc];
}
void down(int k){mx1[lc]+=ly1[k]*hv1[lc];ly1[lc]+=ly1[k];mx2[lc]+=ly2[k]*hv2[lc];ly2[lc]+=ly2[k];mx3[lc]+=ly3[k]*hv2[lc];ly3[lc]+=ly3[k];mx1[rc]+=ly1[k]*hv1[rc];ly1[rc]+=ly1[k];mx2[rc]+=ly2[k]*hv2[rc];ly2[rc]+=ly2[k];mx3[rc]+=ly3[k]*hv2[rc];ly3[rc]+=ly3[k];ly1[k]=ly2[k]=ly3[k]=0;
}
void ch(int k,int l,int r,int x,int y,long long t,int u){if(l>=x&&r<=y){mx1[k]+=t*hv1[k];ly1[k]+=t;mx2[k]+=t*hv2[k];ly2[k]+=t;mx3[k]+=t*dep[u]*hv2[k];ly3[k]+=t*dep[u];return;}if(l>y||r<x) return;if(l==r) return;if(ly1[k]||ly2[k]||ly3[k]) down(k);int mid=l+r>>1;if(x<=mid) ch(lc,l,mid,x,y,t,u);if(y>mid) ch(rc,mid+1,r,x,y,t,u);mx1[k]=mx1[lc]+mx1[rc];mx2[k]=mx2[lc]+mx2[rc];mx3[k]=mx3[lc]+mx3[rc];
}
void find(int k,int l,int r,int x,int y,int u){if(l>=x&&r<=y){ans+=4ll*(mx1[k]-mx2[k]*dep[u]-mx3[k]);return;}if(l>y||r<x) return;if(l==r) return;if(ly1[k]||ly2[k]||ly3[k]) down(k);int mid=l+r>>1;if(x<=mid) find(lc,l,mid,x,y,u);if(y>mid) find(rc,mid+1,r,x,y,u);
}
void ask(int i){int t=i;while(i>=1){find(1,1,s[0],s[tp[i]],s[i],t);i=fa[tp[i]];}
}
void ins(int i){int t=i;while(i>=1){ch(1,1,s[0],s[tp[i]],s[i],1,t);i=fa[tp[i]];}
}
void del(int i){int t=i;while(i>=1){ch(1,1,s[0],s[tp[i]],s[i],-1,t);i=fa[tp[i]];}
}
int main()
{scanf("%d%d",&n,&k);++n;for(int i=1;i<n;i++){scanf("%d%d",&x,&y);++x;++y;add(x,y);add(y,x);}dfs1(1,0);s[1]=++s[0];re[s[0]]=1;tp[1]=1;dfs2(1,0);build(1,1,s[0]);long long sum1=0,sum2=0;for(int i=2,vt,vk=2;i<=n;i++){vt=max(2,i-k);while(vk<vt){sum1-=1ll*dep[vk]*dep[vk];sum2-=1ll*dep[vk];del(vk);++vk;}ans=1ll*(dep[i]-1)*(dep[i]-1)+1ll*(i-vt)*dep[i]*dep[i]+sum1+2ll*dep[i]*sum2;ask(i);printf("%lld\n",ans);sum1+=1ll*dep[i]*dep[i];sum2+=1ll*dep[i];ins(i);}return 0;
}
相关文章:
2021牛客OI赛前集训营-提高组(第四场) T3快速访问
2021牛客OI赛前集训营-提高组(第四场) 题目大意 有一棵n1n1n1个节点的树,根节点为0。给你一个kkk,定义集合Si{j∈Z∣max(1,i−k)≤j<i}∪{0}S_i\{j\in Z|\max(1,i-k)\leq j<i\}\cup\{0\}Si{j∈Z∣max(1,i−k)≤j<i…...
【大数据是什么】
大数据是什么大数据是做什么的?大数据主要有哪些职位 ?大数据运维工程师数据仓库开发工程师ETL工程师大数据开发工程师BI工程师算法工程师大数据平台开发工程师大数据架构师讲述一下自己的大数据学习之路大数据是做什么的? 2014年,…...
大数据 | centos7图形界面无法执行yum命令
大家好,今天是三八女神节了! 你知道吗?世界上第一位电脑程序设计师是名女性,Ada Lovelace (1815-1852)。 她是一位英国数学家兼作家,第一位主张计算机不只可以用来算数的人,也发表了第一段分析机用的演算…...
三维人脸实践:基于Face3D的渲染、生成与重构 <一>
face3d: Python tools for processing 3D face git code: https://github.com/yfeng95/face3d paper list: PaperWithCode 该方法广泛用于基于三维人脸关键点的人脸生成、属性检测(如位姿、深度、PNCC等),能够快速实现人脸建模与渲染。推荐…...
Javascript 设计模式
设计模式的五大设计原则(SOLID)单一职责:一个程序只需要做好一件事。如果功能过于复杂就拆分开,保证每个部分的独立开放封闭原则:对扩展开放,对修改封闭。增加需求时,扩展新代码,而不是修改源代码。这是软件设计的终极…...
JAVA-文档工具screw-gui
前言 为什么萌生了写文档工具得想法,因为在项目开发得过程中,经常需要补充一些文档,比如数据库文档、详细设计文档等等,文档与项目相绑定,在项目需求新增或变更时,文档也需要反反复复得修改。 1. 数据库…...
开源鸿蒙南向嵌入学习笔记——NAPI框架学习(一)
开源鸿蒙南向嵌入学习笔记——NAPI框架学习(一) 前言——系列介绍 本系列文章主要是记录笔者在鸿蒙南向的学习与工作中的知识点笔记记录,其中不止会针对鸿蒙中的学习问题进行思考与记录,也会对涉及到的一些嵌入式等其他领域知识&…...
Spring - Spring框架概述面试题总结
文章目录01. 什么是Spring?02. Spring框架的设计目标,设计理念,和核心是什么?03. Spring的优点是什么?04. Spring框架中都用到了哪些设计模式?05. Spring有哪些应用场景?06. Spring由哪些模块组成…...
学习python好就业么
Python的普及与数据挖掘、人工智能和数值计算等领域的蓬勃发展相关,但同时也与普遍编程需求的增加有关。 Python作为人工智能的头号语言,一方面会吸引大量计划从事人工智能的人来学习,另一方面自然也带动了网络上对这门“新语言”的关注和讨…...
瑞幸咖啡的最终目标并不是做国内市场大哥
出品 | 何玺 排版 | 叶媛 日前,瑞幸咖啡发布2022年第四季度及全年财报。数据显示,在刚刚过去的2022年,瑞幸咖啡首次实现了营收超百亿,门店规模也超越老对手星巴克,成为了国内第一连锁咖啡品牌。 那么,瑞幸…...
GPT 模型介绍 | GPT3 / GPT3.5 + Flask | Github源码链接
1. 模型介绍 Chatgpt 使用与 InstructGPT相同的方法,使用来自人类反馈的强化学习 (RLHF) 来训练该模型,但数据收集设置略有不同。我们使用监督微调训练了一个初始模型:人类 AI 训练员提供对话,他们在对话中扮演双方——用户和 AI…...
蓝桥杯入门即劝退(二十六)组合问题(回溯算法)
-----持续更新Spring入门系列文章----- 如果你也喜欢Java和算法,欢迎订阅专栏共同学习交流! 你的点赞、关注、评论、是我创作的动力! -------希望我的文章对你有所帮助-------- 专栏:蓝桥杯系列 一、题目描述 给定两个整数 n …...
现代卷积神经网络(ResNet)
专栏:神经网络复现目录 本章介绍的是现代神经网络的结构和复现,包括深度卷积神经网络(AlexNet),VGG,NiN,GoogleNet,残差网络(ResNet),稠密连接网络…...
PTA:L1-019 谁先倒、L1-020 帅到没朋友、L1-021 重要的话说三遍(C++)
目录 L1-019 谁先倒 问题描述: L1-020 帅到没朋友 问题描述: 实现代码(只过了部分): L1-021 重要的话说三遍 问题描述: 实现代码: 无解析 L1-019 谁先倒 问题描述: 划拳是…...
STL常见容器之set/multiset、map/multimap
set/multiset—集合容器 特点 所有元素都会在插入时自动被排序 本质 set/multiset属于关联式容器,底层结构是二叉树实现 set和multiset区别 set不可以插入重复数据,而multiset可以set插入数据的同时会返回插入结果,表示插入是否成功multiset…...
ThreadLocal 实现原理
每个 Thread 中都存储着一个成员变量:ThreadLocalMap /** InheritableThreadLocal values pertaining to this thread. This map is* maintained by the InheritableThreadLocal class.*/ThreadLocal.ThreadLocalMap inheritableThreadLocals null; ThreadLocal 本…...
BUUCTF [羊城杯 2020]easyre 题解
一.查壳 64位无壳 二.主函数逻辑 可以得知flag长度为38,然后进行三次加密 第一次加密是base64加密,得到code1 第二次加密是将code1拆成四段赋给code2 第三次加密是将code2内的数字和字母移3位,其他字符不变 str2保存的是最终的加密字符 三.encode_one_base64 看到主函数…...
网络协议(十二):HTTPS(SSL/TLS、TLS1.2的连接)
网络协议系列文章 网络协议(一):基本概念、计算机之间的连接方式 网络协议(二):MAC地址、IP地址、子网掩码、子网和超网 网络协议(三):路由器原理及数据包传输过程 网络协议(四):网络分类、ISP、上网方式、公网私网、NAT 网络…...
九九乘法表--课后程序(Python程序开发案例教程-黑马程序员编著-第3章-课后作业)
实例9:九九乘法表 乘法口诀是中国古代筹算中进行乘法、除法、开方等运算的基本计算规则,沿用至今已有两千多年。古代的乘法口诀与现在使用的乘法口诀顺序相反,自上而下从“九九八十一”开始到“一一如一”为止,因此,古…...
在超算上安装文件树命令tree
超算平台使用的centos系统没有内置tree命令,需要通过源码安装。记录安装流程如下。 1. 下载源码包 下载链接如下: http://mama.indstate.edu/users/ice/tree/ 选择“Download the latest version” 如本文下载了源码包“tree-2.1.0.tgz”. 2. 源码包…...
论文投稿指南——中文核心期刊推荐(经济管理)
【前言】 🚀 想发论文怎么办?手把手教你论文如何投稿!那么,首先要搞懂投稿目标——论文期刊 🎄 在期刊论文的分布中,存在一种普遍现象:即对于某一特定的学科或专业来说,少数期刊所含…...
在vue中如果computed属性是一个异步操作怎么办?
在计算属性中使用异步方法时,可以使用async/await来处理异步操作。由于计算属性是基于它们的依赖缓存的,所以我们需要使用一个返回Promise的异步方法来确保计算属性能够正常运行。 下面是一个简单的示例,演示如何在计算属性中使用异步方法&am…...
SRP合批问题
1)SRP合批问题 2)多个Base相机渲染到同一个渲染目标,移动平台花屏的问题 3)粒子系统对GPU Instancing的支持 4)如何修改URP下场景和UI分辨率分离(不需要改颜色空间) 这是第327篇UWA技术知识分…...
蓝牙5.1低功耗SOC 私有协议2.4GHz芯片HS6621
HS6621CxC是一个优化功耗真正芯片系统(SOC)解决方案,适用于蓝牙低功耗和私有的2.4GHz应用场景。它集成了一个高性能、小功率的射频收发器,具有蓝牙基带和丰富的外围IO扩展。还集成了电源管理,以提供高效的电源管理。 …...
数据库连接池
数据库连接---执行完毕---释放 连接--释放 十分浪费系统资源 池化技术:准备一些预先的资源,过来就连接预先准备好的 最小连接数: 10 最大连接数:15 业务最高承载上限 排队等待, 等待超时:100…...
Arrays-sort-的用法
1.集合交换元素 Collections.swap(List<?> list, int i, int j); 源码: /*** Swaps the elements at the specified positions in the specified list.* (If the specified positions are equal, invoking this method …...
华为OD机试真题Java实现【寻找相同子串】真题+解题思路+代码(20222023)
寻找相同子串 题目 给你两个字符串 t 和 p ,要求从 t 中找到一个和 p 相同的连续子串,并输出该字串第一个字符的下标。 🔥🔥🔥🔥🔥👉👉👉👉👉👉 华为OD机试(Java)真题目录汇总 输入描述: 输入文件包括两行,分别表示字符串 t 和 p ,保证 t 的长度…...
性能指标 确定性能目标 性能场景设计
性能测试指标 性能测试指标分为业务技术指标和系统资源指标,在服务端性能业务技术指标中分为三个指标,系统吞吐量,响应时间和并发用户数。响应时间分为前端展现时间和系统响应时间两部分,系统吞吐量体现软件系统负载承受能力的指…...
ENVI_Classic:快速入门_菜单栏常见功能的基本介绍
说明:由于实验要求,所以并没有对各个功能进行详尽的解释,大多点到为止,少部分实验内容是实验要求所以步骤详尽。当然由于经验不足,有一些可能存在错误恳请指正.1. 实验目的通过ENVI Classic对自行下载的遥感图像进行一…...
【深度探讨】公共部门在选择区块链平台时要考虑的6个方面
发表时间:2022年8月17日 信息来源:bsvblockchain.org 与私营企业相比,全球的公共部门组织在考虑升级软件解决方案时面临着一系列的全新挑战。公共部门的决策流程冗长而复杂,他们要不惜一切代价避免对现有业务造成干扰,…...
公众号网站怎么建/微信视频号可以推广吗
源代码包 在Linux、BSD系统中,软件包主要以两种形式出现:二进制包以及源代码包。 之前一直说的rpm包就是属于二进制包,也就是已经编译好的软件包. 这里说源代码包则主要适用于自由软件的安装,用户需要自己编译它们。 先了解下:源码安装和r…...
国外的网站建设/新业务在线软件下载
ECC加密算法入门介绍 前言 同RSA(Ron Rivest,Adi Shamir,Len Adleman三位天才的名字)一样,ECC(Elliptic Curves Cryptography,椭圆曲线密码编码学)也属于公开密钥算法。目前&#x…...
精品课程网站建设情况/百度电脑版网址
vim 工具我们大家用的都很多,写shell,编代码,都会经常用到,我用了vim也很长时间了,有时候会涉及到会批量添加操作,其实vim提供了很好的环境与命令。。。。。就是他的可视模式。。。 先抓两个图 给大家 1.所…...
桥头网站建设/大数据精准获客软件
使用方法: 需要右滑返回的activity继承baseActivity就可以, 如: public class SettingActivity extends BaseActivity {} 为防止滑动出现黑屏效果,记得需要定义 <!-- 滑动activity必须使用该主题,防侧滑时黑屏 --&g…...
南昌企业建站系统/云盘网页版登录
考研复试系列——第七节 最短路径 前言 前面我们学习了DFS算法,利用DFS算法,我们以每一个顶点为开始节点进行DFS,最后进行比较也可以求得最短路径,但是复杂度不能满足我们的需求。现在我们通过Floyd算法和Dijkstra算法来解决最短…...
潍坊一品网站制作/推广自己的产品
收集整理一些Linux下snmp常用的OID,用做服务器监控很不错。 应用示例 查看服务器1分钟平均负载: snmpwalk -v1 -c public 127.0.0.1 .1.3.6.1.4.1.2021.10.1.3.1 UCD-SNMP-MIB::laLoad.1 STRING: 0.25 查看服务器当前连接: snmpwalk -v1 -c …...