萌神的考试第三题
根据题目中所给出的插入条件,我们可以得出,i节点的father不是第一个比他大的就是第一个比他小的,而在这两个数之中,选择插入时间比较晚的就是i节点的father
代码如下(感谢yousiki)
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<set>
#include<map>
using namespace std;
set <int> s;//从小到大排序,且没有重复的数
set <int>::iterator it;
map <int,int> m;
int main(){
int n;
cin>>n;
for(int i=1,x;i<=n;i++){
scanf("%d",&x);
if(i!=1){
it=s.lower_bound(x);//寻找序列中第一个比x的数
if(it==s.begin()){//如果序列中没有比x小的数,那么x的father一定是第一个比它大的数
printf("%d ",*it);
s.insert(x);
m[x]=i;//记录插入时间
}
else if(it==s.end()){
printf("%d ",*(--it));
s.insert(x);
m[x]=i;
}
else{
int a=*it,b=*(--it);
if(m[a]>m[b])
printf("%d ",a);
else
printf("%d ",b);
s.insert(x);
m[x]=i;
}
}
else
s.insert(x),m[x]=i;
}
return 0;
}
代码 by yousiki
by >o< neighthorn
本文解析了萌神考试中的第三题,通过使用C++实现了一种数据结构算法来确定节点的父亲节点。具体来说,对于每一个插入的节点i,算法会判断其父亲节点是第一个比i大的节点还是第一个比i小的节点,并且当存在多个候选节点时选择插入时间较晚的那个作为父亲节点。
290

被折叠的 条评论
为什么被折叠?



