【BZOJ 2733】 [HNOI2012]永无乡|Splay启发式合并

2024-03-02 21:48

本文主要是介绍【BZOJ 2733】 [HNOI2012]永无乡|Splay启发式合并,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

代码能力太弱

#include <cstdio>
#include <iostream>
#include <algorithm> 
using namespace std;
#define MAXN 100010
int father[MAXN],root[MAXN];
int fa[MAXN],to[MAXN][2],size[MAXN],num[MAXN],id[MAXN];
int n,m;
int laji[MAXN],top;
void Up(int x){ size[x]=size[to[x][0]]+size[to[x][1]]+1; }
void Rotate(int &rt,int x)
{int y=fa[x],z=fa[y];if(y==rt) rt=x;else to[z][to[z][1]==y]=x;int c=to[y][1]==x;fa[x]=z;fa[y]=x;fa[to[x][c^1]]=y;to[y][c]=to[x][c^1];to[x][c^1]=y;Up(y);Up(x); 
}
void Splay(int &rt,int x)
{while(rt!=x){if(fa[x]!=rt) Rotate(rt,fa[x]);Rotate(rt,x);}
}
void Ins(int &now,int &rt,int ID,int NUM,int last)
{if(now==0){now=laji[top--];num[now]=NUM;id[now]=ID;fa[now]=last;size[now]=1;Splay(rt,now);return ;}if(NUM<=num[now]) Ins(to[now][0],rt,ID,NUM,now);else Ins(to[now][1],rt,ID,NUM,now);
}
void Dfs(int &rt,int now)
{if(now==0) return ;Dfs(rt,to[now][0]);Dfs(rt,to[now][1]);Ins(rt,rt,id[now],num[now],0);fa[now]=to[now][0]=to[now][1]=size[now]=id[now]=num[now]=0;laji[++top]=now;
}
int F(int x)
{if(father[x]!=x) father[x]=F(father[x]);return father[x];
}
void Link(int x,int y)
{x=F(x);y=F(y);if(x==y) return ;int sx=size[root[x]];int sy=size[root[y]];if(sx<sy) swap(x,y);Dfs(root[x],root[y]);father[y]=x;
}
int Q(int now,int k)
{if(now==0) return -1;int tmp=size[now]-size[to[now][1]];if(tmp==k) return id[now];else if(tmp<k) return Q(to[now][1],k-tmp);else return Q(to[now][0],k);
}
int main()
{cin >>n >>m;int x,y,q;char s[20];for(int i=1;i<MAXN;i++) laji[++top]=i;for(int i=1;i<MAXN;i++) father[i]=i; for(int i=1;i<=n;i++) scanf("%d",&x),Ins(root[i],root[i],i,x,0);for(int i=1;i<=m;i++) scanf("%d %d",&x,&y),Link(x,y);cin >>q;while(q--){scanf("%s %d %d",s+1,&x,&y);	if(s[1]=='Q') printf("%d\n",Q(root[F(x)],y));else Link(x,y);}return 0;
}


这篇关于【BZOJ 2733】 [HNOI2012]永无乡|Splay启发式合并的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python自动化办公之合并多个Excel

《Python自动化办公之合并多个Excel》在日常的办公自动化工作中,尤其是处理大量数据时,合并多个Excel表格是一个常见且繁琐的任务,下面小编就来为大家介绍一下如何使用Python轻松实现合... 目录为什么选择 python 自动化目标使用 Python 合并多个 Excel 文件安装所需库示例代码

使用Python合并 Excel单元格指定行列或单元格范围

《使用Python合并Excel单元格指定行列或单元格范围》合并Excel单元格是Excel数据处理和表格设计中的一项常用操作,本文将介绍如何通过Python合并Excel中的指定行列或单... 目录python Excel库安装Python合并Excel 中的指定行Python合并Excel 中的指定列P

基于C#实现PDF文件合并工具

《基于C#实现PDF文件合并工具》这篇文章主要为大家详细介绍了如何基于C#实现一个简单的PDF文件合并工具,文中的示例代码简洁易懂,有需要的小伙伴可以跟随小编一起学习一下... 界面主要用于发票PDF文件的合并。经常出差要报销的很有用。代码using System;using System.Col

Python视频剪辑合并操作的实现示例

《Python视频剪辑合并操作的实现示例》很多人在创作视频时都需要进行剪辑,本文主要介绍了Python视频剪辑合并操作的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录介绍安装FFmpegWindowsMACOS安装MoviePy剪切视频合并视频转换视频结论介绍

不删数据还能合并磁盘? 让电脑C盘D盘合并并保留数据的技巧

《不删数据还能合并磁盘?让电脑C盘D盘合并并保留数据的技巧》在Windows操作系统中,合并C盘和D盘是一个相对复杂的任务,尤其是当你不希望删除其中的数据时,幸运的是,有几种方法可以实现这一目标且在... 在电脑生产时,制造商常为C盘分配较小的磁盘空间,以确保软件在运行过程中不会出现磁盘空间不足的问题。但在

在C#中合并和解析相对路径方式

《在C#中合并和解析相对路径方式》Path类提供了几个用于操作文件路径的静态方法,其中包括Combine方法和GetFullPath方法,Combine方法将两个路径合并在一起,但不会解析包含相对元素... 目录C#合并和解析相对路径System.IO.Path类幸运的是总结C#合并和解析相对路径对于 C

hdu2241(二分+合并数组)

题意:判断是否存在a+b+c = x,a,b,c分别属于集合A,B,C 如果用暴力会超时,所以这里用到了数组合并,将b,c数组合并成d,d数组存的是b,c数组元素的和,然后对d数组进行二分就可以了 代码如下(附注释): #include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<que

day-51 合并零之间的节点

思路 直接遍历链表即可,遇到val=0跳过,val非零则加在一起,最后返回即可 解题过程 返回链表可以有头结点,方便插入,返回head.next Code /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}*

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点

【Python从入门到进阶】64、Pandas如何实现数据的Concat合并

接上篇《63.Pandas如何实现数据的Merge》 上一篇我们学习了Pandas如何实现数据的Merge,本篇我们来继续学习Pandas如何实现数据的Concat合并。 一、引言 在数据处理过程中,经常需要将多个数据集合并为一个统一的数据集,以便进行进一步的分析或建模。这种需求在多种场景下都非常常见,比如合并不同来源的数据集以获取更全面的信息、将时间序列数据按时间顺序拼接起来以观察长期趋势等