XOJ 4.树的构造

本文解析了萌神考试中的第三题,通过使用C++实现了一种数据结构算法来确定节点的父亲节点。具体来说,对于每一个插入的节点i,算法会判断其父亲节点是第一个比i大的节点还是第一个比i小的节点,并且当存在多个候选节点时选择插入时间较晚的那个作为父亲节点。

萌神的考试第三题
根据题目中所给出的插入条件,我们可以得出,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

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值