华为OD机试真题-计算三叉搜索树的高度-2023年OD统一考试(C卷)

题目描述:

定义构造三叉搜索树规则如下:
    每个节点都存有一个数,当插入一个新的数时,从根节点向下寻找,直到找到一个合适的空节点插入。
    查找的规则是:
        1. 如果数小于节点的数减去500,则将数插入节点的左子树
        2. 如果数大于节点的数加上500,则将数插入节点的右子树
        3. 否则,将数插入节点的中子树
给你一系列数,请按以上规则,按顺序将数插入树中,构建出一棵三叉搜索树,最后输出树的高度。

输入描述:第一行为一个数N,表示有N个数,1<=N<=10000
第二行为N个空格分隔的整数,每个数的范围为[1,10000]

输出描述:输出树的高度(根节点的高度为1)

补充说明:

示例1

输入:

5
5000 2000 5000 8000 1800

输出:

3

说明:

最终构造出的树如下,高度为3:

示例2

输入:

3
5000 4000 3000

输出:

3

说明:

最终构造出的树如下,高度为3:

import java.

最近更新

  1. TCP协议是安全的吗?

    2024-01-11 12:52:01       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-11 12:52:01       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-11 12:52:01       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-11 12:52:01       18 阅读

热门阅读

  1. 【打卡】牛客网:BM79 打家劫舍(二)

    2024-01-11 12:52:01       41 阅读
  2. 算法:A*算法最小实例

    2024-01-11 12:52:01       34 阅读
  3. C++经典程序

    2024-01-11 12:52:01       35 阅读
  4. 【金融支付】常用术语和定义

    2024-01-11 12:52:01       32 阅读
  5. 一、SpringBoot框架搭建

    2024-01-11 12:52:01       34 阅读
  6. C/C++-传值/地址的区别

    2024-01-11 12:52:01       28 阅读
  7. 在IntelliJ IDEA中,.idea文件是什么,可以删除吗

    2024-01-11 12:52:01       33 阅读
  8. Crow:路由局部插件2 调用before_handle

    2024-01-11 12:52:01       40 阅读
  9. C++入门级程序day1

    2024-01-11 12:52:01       36 阅读