将其按照区间分块(即$[(i-1)K+1,iK]$作为一个块),并定义$f_{x}$表示$x$的祖先中编号最小且与$x$在同一个块内的节点,$f_{x}$可以通过$f_{a_{x}}$转移,即$f_{x}=\begin{cases}f_{a_{x}}\ \ \ (x与a_{x}在一个块中)\\x\ \ \ \ \ \ (x与a_{x}不在一个块中)\end{cases}$

(特别的,若$x$在第一个块中则$f_{x}=1$)

通过$f_{x}$,类似于树剖的方式,即若两者$f_{x}$不同则移动$f_{x}$较大的(移动到$f_{x}$),直至相同再用同样的方式爬$a_{x}$,复杂度显然是$o(q\sqrt{n})$的

接下来是如何维护$f_{x}$,即如何支持修改:

对于边角的两个块,显然是可以暴力维护的,对于整块修改,显然当一个块被修改$\sqrt{n}$次后一定有$f_{x}=x$,因此至多$o(n)$次暴力,复杂度也是$o(n\sqrt{n})$

最终总复杂度即为$o((n+q)\sqrt{n})$

 1 #include<bits/stdc++.h>
2 using namespace std;
3 #define N 100005
4 int n,m,K,p,x,y,z,a[N],bl[N],st[N],ed[N],f[N];
5 long long tag[N];
6 int get(int k){
7 return max(a[k]-tag[bl[k]],1LL);
8 }
9 void calc(int x,int y){
10 for(int i=x;i<=y;i++)
11 if (bl[i]==1)f[i]=1;
12 else{
13 int x=get(i);
14 if (bl[x]!=bl[i])f[i]=i;
15 else f[i]=f[x];
16 }
17 }
18 int main(){
19 scanf("%d%d",&n,&m);
20 for(int i=2;i<=n;i++)scanf("%d",&a[i]);
21 K=(int)sqrt(n);
22 for(int i=1;i<=n;i++)bl[i]=(i-1)/K+1;
23 for(int i=1;i<=bl[n];i++){
24 st[i]=(i-1)*K+1;
25 ed[i]=min(i*K,n);
26 calc(st[i],ed[i]);
27 }
28 calc(1,n);
29 for(int i=1;i<=m;i++){
30 scanf("%d%d%d",&p,&x,&y);
31 if (p==1){
32 scanf("%d",&z);
33 if (bl[x]==bl[y]){
34 for(int j=x;j<=y;j++)a[j]=max(a[j]-z,1);
35 calc(st[bl[x]],ed[bl[x]]);
36 }
37 else{
38 for(int j=x;j<=ed[bl[x]];j++)a[j]=max(a[j]-z,1);
39 calc(st[bl[x]],ed[bl[x]]);
40 for(int j=st[bl[y]];j<=y;j++)a[j]=max(a[j]-z,1);
41 calc(st[bl[y]],ed[bl[y]]);
42 for(int j=bl[x]+1;j<=bl[y]-1;j++){
43 tag[j]+=z;
44 if (tag[j]-z<=K)calc(st[j],ed[j]);
45 }
46 }
47 }
48 else{
49 while (f[x]!=f[y]){
50 if (f[x]>f[y])swap(x,y);
51 y=get(f[y]);
52 }
53 if (x==y){
54 printf("%d\n",x);
55 continue;
56 }
57 while (get(x)!=get(y)){
58 if (get(x)>get(y))swap(x,y);
59 y=get(y);
60 }
61 if (x==y)printf("%d\n",x);
62 else printf("%d\n",get(x));
63 }
64 }
65 }

[cf1491H]Yuezheng Ling and Dynamic Tree的更多相关文章

  1. Codeforces 1491H - Yuezheng Ling and Dynamic Tree(分块)

    Codeforces 题目传送门 & 洛谷题目传送门 *3400 的毒瘤 H 题,特意写个题解纪念一下( 首先对于这种数据结构不太好直接维护的东东可以考虑分块.然鹅我除了分块其他啥也没想到 我 ...

  2. Solution -「CF 1491H」Yuezheng Ling and Dynamic Tree

    \(\mathcal{Description}\)   Link. 做题原因:题目名.   给定一个长度 \(n-1\) 的序列 \(\{a_2,a_3,\cdots,a_n\}\),其描述了一棵 \ ...

  3. 10+ 最流行的 jQuery Tree 菜单插件

    jstree – jQuery Tree Plugin With HTML & JSON Data jstree is a lightweight and flexible jQuery pl ...

  4. java基础十[包、Jar存档文件和部署](阅读Head First Java记录)

    将Java的class文件生成为可执行的Java应用程序.Java应用程序有三种:完全在本机执行的Jar(例如本机的GUI可执行程序):完全在服务器端远程执行的(例如浏览器来进行存取):介于两者之间的 ...

  5. FTP客户端上传下载Demo实现

    1.第一次感觉MS也有这么难用的MFC类: 2.CFtpFileFind类只能实例化一个,多个实例同时查找会出错(因此下载时不能递归),采用队列存储目录再依次下载: 3.本程序支持文件夹嵌套上传下载: ...

  6. [ActionScript 3.0] Away3D 官网实例

    /* Dynamic tree generation and placement in a night-time scene Demonstrates: How to create a height ...

  7. PeopleCode事件和方法只用于online界面不能用于组件接口(component interface)

    在使用CI过程中,哪些方法是不能使用的.以下为PeopleBook解释的内容. 一.搜索框代码不执行:SearchInit, SearchSave, and RowSelect events 意味着使 ...

  8. table2excel使用

    原table2excel代码 /* * 采用jquery模板插件——jQuery Boilerplate * * Made by QuJun * 2017/01/10 */ //table2excel ...

  9. dhtmlxtree 如何得到xml,json等文件中的自定义的属性值

    先看代码: var TreeForJSON = new dhtmlXTreeObject('TreeForJSON', '100%', '100%', 0); TreeForJSON.setImage ...

随机推荐

  1. Java秘诀!零基础怎样快速学习Java?

    对于零基础想学Java的朋友,其实一开始最应该做的就是定好学习目标和端正学习态度,切记不要三天打鱼两天晒网! 首先你是零基础,现在急需把Java学好,在保证学习质量的同时,用最短的时间学好Java应该 ...

  2. pure-ftpd管理FTP服务器,创建文件夹可以,但上传下载文件不行

    两种原因 1.因为pure-ftpd的防火墙端口问题 # Port range for passive connections replies. - for firewalling. PassiveP ...

  3. Mysql双主双从高可用集群的搭建且与MyCat进行整合

    1.概述 老话说的好:瞻前顾后.患得患失只会让我们失败,下定决心,干就完了. 言归正传,之前我们聊了Mysql的一主一从读写分离集群的搭建,虽然一主一从或一主多从集群解决了并发读的问题,但由于主节点只 ...

  4. 串的模式匹配 BF算法和KMP算法

    设有主串s和子串t,子串t的定位就是要在主串中找到一个与子串t相等的子串.通常把主串s称为目标串,把子串t称为模式串,因此定位也称为模式匹配. 模式匹配成功是指在目标串s中找到一个模式串t: 不成功则 ...

  5. 2021能源PWN wp

    babyshellcode 这题考无write泄露,write被沙盒禁用时,可以考虑延时盲注的方式获得flag,此exp可作为此类型题目模版,只需要修改部分参数即可,详细见注释 from pwn im ...

  6. 万里阳光号Srcum Metting博客汇总

    Srcum Meeting 一.Alpha阶段 第一次Scrum Meeting 第二次Scrum Meeting 第三次Scrum Meeting 第四次Scrum Meeting 第五次Scrum ...

  7. 第六次Alpha Scrum Meeting

    本次会议为Alpha阶段第六次Scrum Meeting会议 会议概要 会议时间:2021年5月2日 会议地点:线上会议 会议时长:20min 会议内容简介:本次会议主要由每个人展示自己目前完成的工作 ...

  8. spring cloud config的使用

    在传统的应用中,我们的配置文件都是放在项目中,这个影响不大.但是在一个微服务架构的系统中,我们的微服务可能存在几十上百个,并且每个小的微服务可能又部署在多台机器上,那么这个时候如果我们的配置文件在都放 ...

  9. VS2019、Qt5.12及QGis3.16开发常见问题汇总

    在C++.Qt软件开发过程中,常常遇到一些编译错误或警告:本文将VS2019.Qt5.12.10和QGis3.16.10的二次开发过程常见的问题做了整理,供大家参考,也便于日后查阅.该内容分为四部分: ...

  10. 图像原始格式(YUV444 YUV422 YUV420)一探究竟

    前段时间搞x264编码测试,传参的时候需要告诉编码器我的原始数据格式是什么,其中在x264.h头文件中定义了如下一堆类型. /* Colorspace type */ #define X264_CSP ...