PAT 二叉树打卡

acwing:1605. 二叉搜索树最后两层结点数量

二叉搜索树 (BST) 递归定义为具有以下属性的二叉树:

  • 若它的左子树不空,则左子树上所有结点的值均小于或等于它的根结点的值
  • 若它的右子树不空,则右子树上所有结点的值均大于它的根结点的值
  • 它的左、右子树也分别为二叉搜索树

将一系列数字按顺序插入到一个空的二叉搜索树中,然后,请你计算结果树的最低两层的结点个数。

输入格式

第一行包含整数 NN,表示插入数字序列包含的数字个数。

第二行包含 NN 个整数,表示插入数字序列。

输出格式

以如下格式,在一行中,输出结果树的最后两层的结点数:

复制代码
n1 + n2 = n

n1 是最底层结点数量,n2 是倒数第二层结点数量,n 是它们的和。

数据范围

1≤N≤10001≤N≤1000,

−1000≤−1000≤ 插入数字 ≤1000≤1000。

输入样例:
复制代码
9
25 30 42 16 20 20 35 -5 28
输出样例:
复制代码
2 + 4 = 6
cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
const int N=1010;

int n;

struct tree{
    int val;
    int h;
    int l,r;
}p[N];
int max_h;
int cnt[N];
void build(int root,int u,int h){
    if(p[root].val>=p[u].val){
        if(p[root].l==0x3f3f3f3f){
            p[root].l=u;
            p[u].h=h+1;
            max_h=max(max_h,p[u].h);
            //cout<<max_h<<endl;
            cnt[p[u].h]++;
        }else{
            build(p[root].l,u,h+1);
        }
    }else{
        if(p[root].r==0x3f3f3f3f){
            p[root].r=u;
            p[u].h=h+1;
            max_h=max(max_h,p[u].h);
           // cout<<max_h<<endl;
            cnt[p[u].h]++;
        }else{
            build(p[root].r,u,h+1);
        }
    }
}
void init()
{
    for(int i=0;i<N;i++){
        p[i].l=p[i].r=0x3f3f3f3f;
    }
} 
int main()
{
    ios::sync_with_stdio(0);
    cin.tie(0),cout.tie(0);
    cin>>n;
    init();
    if(n==1){
        cout<<"1 + 0 = 1";
    }else{
        for(int i=1;i<=n;i++){
        int x;
        cin>>x;
        if(i==1){
            p[1].val=x;
            p[1].h=1;
        }else{
            p[i].val=x;
            build(1,i,1);
        }
       
    }
    //cout<<max_h<<endl;
    cout<<cnt[max_h]<<" + "<<cnt[max_h-1]<<" = "<<cnt[max_h]+cnt[max_h-1];
    }
    
}
相关推荐
我家大宝最可爱25 分钟前
强化学习基础-拒绝采样
人工智能·算法·机器学习
YuTaoShao1 小时前
【LeetCode 每日一题】面试题 17.12. BiNode
算法·leetcode·深度优先
刘大猫.1 小时前
XNMS项目-拓扑图展示
java·人工智能·算法·拓扑·拓扑图·节点树·xnms
万象.1 小时前
redis数据结构set和zset的基本指令
数据结构·数据库·redis
夏鹏今天学习了吗3 小时前
【LeetCode热题100(95/100)】寻找重复数
算法·leetcode·职场和发展
TTGGGFF6 小时前
控制系统建模仿真(四):线性控制系统的数学模型
人工智能·算法
晚风吹长发7 小时前
初步了解Linux中的命名管道及简单应用和简单日志
linux·运维·服务器·开发语言·数据结构·c++·算法
Σίσυφος19007 小时前
Halcon中霍夫直线案例
算法
夏乌_Wx8 小时前
练题100天——DAY42:移除链表元素 ★★☆☆☆
数据结构
Anastasiozzzz8 小时前
leetcode力扣hot100困难题--4.俩个正序数列的中位数
java·算法·leetcode·面试·职场和发展