无名汉化组官网_neverland永无岛

无名汉化组官网_neverland永无岛永无乡包含 n 座岛,编号从 1 到 n ,每座岛都有自己的独一无二的重要度,按照重要度可以将这 n 座岛排名,名次用 1 到 n 来表示。某些岛之间由巨大的桥连接,通过桥可以从一个岛到达另一个岛。如果从岛 a 出发经过若干座(含 0 座)桥可以到达岛 b ,则称岛 a 和岛 b 是连通的。现在有两种操作:B x y 表示在岛 x 与岛 y 之间修建一座新桥。Q x k 表示询问当前与岛 x 连通的所有岛中第 k 重要的是哪座岛,即所有与岛 x 连通的岛中重要度排名第 k 小的岛是哪座,请你输出那

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

永无乡包含 n 座岛,编号从 1 到 n ,每座岛都有自己的独一无二的重要度,按照重要度可以将这 n 座岛排名,名次用 1 到 n 来表示。

某些岛之间由巨大的桥连接,通过桥可以从一个岛到达另一个岛。

如果从岛 a 出发经过若干座(含 0 座)桥可以到达岛 b ,则称岛 a 和岛 b 是连通的。

现在有两种操作:

B x y 表示在岛 x 与岛 y 之间修建一座新桥。
Q x k 表示询问当前与岛 x 连通的所有岛中第 k 重要的是哪座岛,即所有与岛 x 连通的岛中重要度排名第 k 小的岛是哪座,请你输出那个岛的编号。
输入格式
第一行是用空格隔开的两个正整数 n 和 m ,分别表示岛的个数以及一开始存在的桥数。

接下来的一行是用空格隔开的 n 个数,依次描述从岛 1 到岛 n 的重要度排名。

随后的 m 行每行是用空格隔开的两个正整数 ai 和 bi ,表示一开始就存在一座连接岛 ai 和岛 bi 的桥。

后面剩下的部分描述操作,该部分的第一行是一个正整数 q ,表示一共有 q 个操作,接下来的 q 行依次描述每个操作,操作的格式如上所述,以大写字母 Q 或 B 开始,后面跟两个不超过 n 的正整数,字母与数字以及两个数字之间用空格隔开。

输出格式
对于每个 Q x k 操作都要依次输出一行,其中包含一个整数,表示所询问岛屿的编号。

如果该岛屿不存在,则输出 −1。

数据范围
对于 20 的数据 n≤1000,q≤1000,
对于 100 的数据 n≤100000,m≤n,q≤300000

输入样例:
5 1
4 3 2 5 1
1 2
7
Q 3 2
Q 2 1
B 2 3
B 1 5
Q 2 1
Q 2 4
Q 2 3
输出样例:
-1
2
5
1
2
#include<bits/stdc++.h>
using namespace std;
const int N = 1e5 + 100;
struct Node{ 
   
    int s[2],v,p;
    int size,flag;
    int id;
    void init(int _v,int _p,int _id){ 
   
        v = _v,p  = _p,id = _id;
        size = 1;
    }
}tr[N];
int root[N],ctx;
int w[N];
int f[N];
void pushup(int u){ 
   
    tr[u].size = tr[tr[u].s[0]].size + tr[tr[u].s[1]].size + 1;
}
void pushdown(int u){ 
   
    return;
}
void rotate(int x){ 
   
    int y = tr[x].p,z = tr[y].p;
    int k = tr[y].s[1] == x;
    tr[z].s[tr[z].s[1] == y] = x,tr[x].p = z;
    tr[y].s[k] = tr[x].s[k ^ 1],tr[tr[x].s[k ^ 1]].p = y;
    tr[x].s[k ^ 1] = y,tr[y].p = x;
    pushup(y);
    pushup(x);
}
void splay(int x,int k,int r){ 
   
    while(tr[x].p != k){ 
   
        int y = tr[x].p,z = tr[y].p;
        if(z != k){ 
   
            if((tr[z].s[1] == y) ^ (tr[y].s[1] == x))rotate(x);
            else rotate(y);
        }
        rotate(x);
    }
    if(!k)root[r] = x;
}
int Find(int x){ 
   
    return f[x] = (x == f[x] ? f[x] : Find(f[x]));
}
int insert(int r,int v,int id){ 
           //r代表root[r]
    int u = root[r],p = 0;
    while(u)p = u,u = tr[u].s[v > tr[u].v];
    u = ++ ctx;
    if(p)tr[p].s[v > tr[p].v] = u;
    tr[u].init(v,p,id);
    splay(u,0,r);
    return u;
}
int get_th(int k,int r){ 
   
    int u = root[r];
    while(u){ 
          
        if(tr[tr[u].s[0]].size >= k)u = tr[u].s[0];
        else if(tr[tr[u].s[0]].size + 1 == k)return tr[u].id;
        else k -= tr[tr[u].s[0]].size + 1,u = tr[u].s[1];
    }
    return -1;
}
void dfs(int u,int b){ 
   
    if(tr[u].s[0])dfs(tr[u].s[0],b);
    if(tr[u].s[1])dfs(tr[u].s[1],b);
    insert(b,tr[u].v,tr[u].id);
}
int main(){ 
   
    int n,m;
    cin>>n>>m;
    int x,y;
    for(int i = 1;i <= n;i ++){ 
   
        cin>>x;
        root[i] = f[i] = i;
        tr[i].init(x,0,i);
    }
    ctx = n;
    for(int i = 0;i < m;i ++){ 
   
        cin>>x>>y;
        int a = Find(x),b = Find(y);
        if(a != b){ 
   
            if(tr[root[a]].size > tr[root[b]].size)swap(a,b);//把a插入到b中
            dfs(root[a],b);//合并
            f[a] = b;
        }
    }
    char c;
    cin>>m;
    for(int i = 0;i < m;i ++){ 
   
        cin>>c>>x>>y;
        if(c == 'Q'){ 
   
            int r = Find(x);
            if(y > tr[root[r]].size)cout<<-1<<endl;
            else cout<<get_th(y,r)<<endl;
        }
        else { 
   
            int a = Find(x),b = Find(y);
            if(a != b){ 
   
                if(tr[root[a]].size > tr[root[b]].size)swap(a,b);//把a插入到b中
                dfs(root[a],b);//合并
                f[a] = b;
            }
        }
    }
    return 0;
}
  1. 每一次合并不创建新节点
#include<bits/stdc++.h>
using namespace std;
const int N = 1e5 + 10;
struct Node{ 
   
    int s[2],v,p;
    int size,flag;
    int id;
    void init(int _v,int _p,int _id){ 
   
        v = _v,p  = _p,id = _id;
        size = 1;
    }
}tr[N];
int root[N],ctx;
int w[N];
int f[N];
void pushup(int u){ 
   
    tr[u].size = tr[tr[u].s[0]].size + tr[tr[u].s[1]].size + 1;
}
void pushdown(int u){ 
   
    return;
}
void rotate(int x){ 
   
    int y = tr[x].p,z = tr[y].p;
    int k = tr[y].s[1] == x;
    tr[z].s[tr[z].s[1] == y] = x,tr[x].p = z;
    tr[y].s[k] = tr[x].s[k ^ 1],tr[tr[x].s[k ^ 1]].p = y;
    tr[x].s[k ^ 1] = y,tr[y].p = x;
    pushup(y);
    pushup(x);
}
void splay(int x,int k,int r){ 
   
    while(tr[x].p != k){ 
   
        int y = tr[x].p,z = tr[y].p;
        if(z != k){ 
   
            if((tr[z].s[1] == y) ^ (tr[y].s[1] == x))rotate(x);
            else rotate(y);
        }
        rotate(x);
    }
    if(!k)root[r] = x;
}
int Find(int x){ 
   
    return f[x] = (x == f[x] ? f[x] : Find(f[x]));
}
int insert(int r,int x){ 
           //r代表root[r]
    int u = root[r],p = 0;
    while(u)p = u,u = tr[u].s[tr[x].v > tr[u].v];
    if(p)tr[p].s[tr[x].v > tr[p].v] = x;
    tr[x].p = p;
    splay(x,0,r);
    return u;
}
int get_th(int k,int r){ 
   
    int u = root[r];
    while(u){ 
          
        if(tr[tr[u].s[0]].size >= k)u = tr[u].s[0];
        else if(tr[tr[u].s[0]].size + 1 == k)return tr[u].id;
        else k -= tr[tr[u].s[0]].size + 1,u = tr[u].s[1];
    }
    return -1;
}
void dfs(int u,int b){ 
   
    if(tr[u].s[0])dfs(tr[u].s[0],b);
    if(tr[u].s[1])dfs(tr[u].s[1],b);
    insert(b,u);
}
int main(){ 
   
    int n,m;
    cin>>n>>m;
    int x,y;
    for(int i = 1;i <= n;i ++){ 
   
        scanf("%d",&x);
        root[i] = f[i] = i;
        tr[i].init(x,0,i);
    }
    ctx = n;
    for(int i = 0;i < m;i ++){ 
   
        scanf("%d %d",&x,&y);
        int a = Find(x),b = Find(y);
        if(a != b){ 
   
            if(tr[root[a]].size > tr[root[b]].size)swap(a,b);//把a插入到b中
            dfs(root[a],b);//合并
            f[a] = b;
        }
    }
    char c;
    cin>>m;
    for(int i = 0;i < m;i ++){ 
   
        cin>>c>>x>>y;
        if(c == 'Q'){ 
   
            int r = Find(x);
            if(y > tr[root[r]].size)printf("-1\n");
            else printf("%d\n",get_th(y,r));
        }
        else { 
   
            int a = Find(x),b = Find(y);
            if(a != b){ 
   
                if(tr[root[a]].size > tr[root[b]].size)swap(a,b);//把a插入到b中
                dfs(root[a],b);//合并
                f[a] = b;
            }
        }
    }
    return 0;
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168590.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 〖教程〗Ladon 0day通用执行命令DLL生成器-MS17010演示[通俗易懂]

    〖教程〗Ladon 0day通用执行命令DLL生成器-MS17010演示[通俗易懂]Ladon8.9更新功能20210920[+]CmdDllWindows0day漏洞通用DLL注入生成器,生成的DLL仅5KB,非常适合0day加载2021.9.15[u]webscanCS保留[u]CmdDll去除黑框2021.9.14[+]CVE-2021-40444MicrosoftMSHTML远程代码执行漏洞,Office文档利用模块影响版本:包括Windows7/8/8.1/10,WindowsServer2008/2008R2/2012/2012R2/2016

    2022年5月20日
    46
  • 了解HashMap数据结构,超详细!

    了解HashMap数据结构,超详细!写在前面:小伙伴儿们,大家好!今天来学习HashMap相关内容,作为面试必问的知识点,来深入了解一波!思维导图:学习框架图1,HashMap集合简介HashMap基于哈希表的Map接口实现,是以key-value存储形式存在,即主要用来存放键值对。HashMap的实现不是同步的,这意味着它不是线程安全的。它的key、value都可以为null。此外,HashMap中的映射不是有序的。JDK1.8之前的HashMap由数组+链表组成的,数组是HashMap的主体,链表则是主要为

    2022年5月19日
    41
  • pycharm安装失败_河南新增本土确诊0例无症状

    pycharm安装失败_河南新增本土确诊0例无症状使用Pycharm安装numpy时出现错误,导致安装不上刚刚安装好的pycharm,配置一下插件时总会有一些问题。使用pycharm安装numpy包时,出现pip版本问题,导致无法安装numpy包。简单说,无法安装numpy与pip的版本有关系,需要升级pip的版本。先将pip的版本升级20.0.2,之后再安装numpy包。下面在找到numpy包进行安装,即可使用numpy包中的数组函…

    2025年6月3日
    0
  • java queryinterface_JS和C#访问遇到QueryInterface调用出错「建议收藏」

    java queryinterface_JS和C#访问遇到QueryInterface调用出错「建议收藏」在原来的WinForm里,我们只要在窗体类的头部添加属性[System.Runtime.InteropServices.ComVisibleAttribute(true)],然后webBrowser1.ObjectForScripting=this;这样设置完后,页面上的JS就能访问窗体类的方法了,但是添加WeifenLuo.WinFormsUI.Docking.DockContent作为窗…

    2022年6月16日
    23
  • JS indexOf() 函数[通俗易懂]

    JS indexOf() 函数[通俗易懂]vartest=str1.indexOf(str2);//返回-1表示在str1里没有找到指定的字符串str2的内容.如果有字符串存在就返回它的下表以0开始列子:Strings1=”ahkb”;Strings2=”k”;s1.indexOf(s2)==2;;…

    2022年7月13日
    20
  • k8s最新版本安装_我的世界1.17版本下载

    k8s最新版本安装_我的世界1.17版本下载三分钟安装k8s-v1.20.8版本1.所有机器关闭防火墙,selinux。systemctlstopfirewalldsystemctldisablefirewalldsetenforce0sed-i’s/=enforcing/=disabled/g’/etc/selinux/config2.关闭swap分区swapoff-a#临时sed-i’/swap/s/^/#/’/etc/fstab#永久3.修改内核参数vi/etc/sysctl.d/k8s.c

    2022年9月28日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号