用并查集维护猴子们的关系,强壮值用左偏树维护就行了

Code

#include <cstdio>
#include <algorithm>
#include <cstring>
#define N 100010
using namespace std; int n,fa[N],m,fr[N];
//fr[x]维护猴子x所在集合在左偏树上的编号 int Find(int x){return x==fa[x]?x:fa[x]=Find(fa[x]);}
namespace Lt{
int cnt,l[N],r[N],v[N],d[N];
inline void Init(){
cnt=0;
memset(l,0,sizeof(l)),memset(r,0,sizeof(r));
memset(v,0,sizeof(v)),memset(d,0,sizeof(d));
}
int merge(int x,int y){
if(!x||!y) return x+y;
if(v[x]<v[y]) swap(x,y);
r[x]=merge(r[x],y);
if(d[r[x]]>d[l[x]]) swap(l[x],r[x]);
d[x]=d[r[x]]+1;
return x;
}
inline void clear(int x){l[x]=r[x]=d[x]=0;}//记得一定要清零
} inline int read(){
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9'){x=x*10+ch-'0';ch=getchar();}
return x*f;
} int main(){
while(~scanf("%d",&n)){
Lt::Init();
for(int i=1;i<=n;++i) Lt::v[i]=read(),fa[i]=fr[i]=i;
for(m=read();m--;){
int u=read(),v=read(),px=Find(u),py=Find(v),hhh;
if(px==py) puts("-1");
else{
fa[px]=hhh=py;
u=fr[px],v=fr[py];
int t1=Lt::merge(Lt::l[u],Lt::r[u]),t2=Lt::merge(Lt::l[v],Lt::r[v]);
Lt::clear(u),Lt::v[u]/=2;
Lt::clear(v),Lt::v[v]/=2;
t1=Lt::merge(t1,u),t2=Lt::merge(t2,v);
int x=Lt::merge(t1,t2);
printf("%d\n",Lt::v[x]);
fr[hhh]=x;
}
}
}
return 0;
}
 
 
 
G
M
T
 
检测语言
世界语
中文简体
中文繁体
丹麦语
乌克兰语
乌兹别克语
乌尔都语
亚美尼亚语
伊博语
俄语
保加利亚语
僧伽罗语
克罗地亚语
冰岛语
加利西亚语
加泰罗尼亚语
匈牙利语
南非祖鲁语
卡纳达语
印地语
印尼巽他语
印尼爪哇语
印尼语
古吉拉特语
哈萨克语
土耳其语
塔吉克语
塞尔维亚语
塞索托语
威尔士语
孟加拉语
宿务语
尼泊尔语
巴斯克语
布尔语(南非荷兰语)
希伯来语
希腊语
德语
意大利语
意第绪语
拉丁语
拉脱维亚语
挪威语
捷克语
斯洛伐克语
斯洛文尼亚语
斯瓦希里语
旁遮普语
日语
格鲁吉亚语
毛利语
法语
波兰语
波斯尼亚语
波斯语
泰卢固语
泰米尔语
泰语
海地克里奥尔语
爱尔兰语
爱沙尼亚语
瑞典语
白俄罗斯语
立陶宛语
索马里语
约鲁巴语
缅甸语
罗马尼亚语
老挝语
芬兰语
苗语
英语
荷兰语
菲律宾语
葡萄牙语
蒙古语
西班牙语
豪萨语
越南语
阿塞拜疆语
阿尔巴尼亚语
阿拉伯语
韩语
马其顿语
马尔加什语
马拉地语
马拉雅拉姆语
马来语
马耳他语
高棉语
齐切瓦语
  世界语
中文简体
中文繁体
丹麦语
乌克兰语
乌兹别克语
乌尔都语
亚美尼亚语
伊博语
俄语
保加利亚语
僧伽罗语
克罗地亚语
冰岛语
加利西亚语
加泰罗尼亚语
匈牙利语
南非祖鲁语
卡纳达语
印地语
印尼巽他语
印尼爪哇语
印尼语
古吉拉特语
哈萨克语
土耳其语
塔吉克语
塞尔维亚语
塞索托语
威尔士语
孟加拉语
宿务语
尼泊尔语
巴斯克语
布尔语(南非荷兰语)
希伯来语
希腊语
德语
意大利语
意第绪语
拉丁语
拉脱维亚语
挪威语
捷克语
斯洛伐克语
斯洛文尼亚语
斯瓦希里语
旁遮普语
日语
格鲁吉亚语
毛利语
法语
波兰语
波斯尼亚语
波斯语
泰卢固语
泰米尔语
泰语
海地克里奥尔语
爱尔兰语
爱沙尼亚语
瑞典语
白俄罗斯语
立陶宛语
索马里语
约鲁巴语
缅甸语
罗马尼亚语
老挝语
芬兰语
苗语
英语
荷兰语
菲律宾语
葡萄牙语
蒙古语
西班牙语
豪萨语
越南语
阿塞拜疆语
阿尔巴尼亚语
阿拉伯语
韩语
马其顿语
马尔加什语
马拉地语
马拉雅拉姆语
马来语
马耳他语
高棉语
齐切瓦语
         
 
 
 
文本转语音功能仅限200个字符
 
  选项 : 历史 : 反馈 : Donate 关闭

最新文章

  1. CentOS 6.5 安装 Redis-3.2.6
  2. XML序列化和反序列化
  3. iCheck.js
  4. pod install 慢
  5. PHP OAuth2 Server库
  6. Failed to run the WC DB work queue associated with 错误的解决
  7. 【安装操作系统】VMware 中安装 Redhat 5
  8. Bison executable not found in PATH by mysql install
  9. Java提高学习之Object(4)
  10. HDU 5735 Born Slippy(拆值DP+位运算)
  11. 反射Reflection创建
  12. [转] ESXI6.5 误将硬盘阵列卡配置为passthru直通模式后, 找不到硬盘的问题
  13. Java核心技术卷一基础知识-第3章-Java的基本程序设计结构-读书笔记
  14. ML.NET 示例:推荐之矩阵分解
  15. 【ASP.NET 进阶】TreeView控件学习
  16. [SQL]UNPIVOT 多個欄位
  17. 转:.NET 面试题汇总(一)
  18. [整理]ASP.NET 中异常处理
  19. php中120个内置函数
  20. DBA手记-BBED 的说明

热门文章

  1. ORACLE_ALIAS
  2. asp.net超过字数限制用省略号...表示
  3. nutz 结合QueryResult,Record 自定义分页查询,不构建pojo 整合
  4. Uva 11419 我是SAM
  5. luogu P1121 环状最大两段子段和
  6. Oracle连接问题
  7. Spring data jpa命名规范
  8. 【转】Mac本地生成SSH Key 的方法
  9. JavaScript函数变量作用域
  10. LeetCode2.两数相加 JavaScript