博客
关于我
【树的应用】——列出叶结点 (25分)(附测试点)
阅读量:99 次
发布时间:2019-02-26

本文共 1902 字,大约阅读时间需要 6 分钟。

为了解决这个问题,我们需要构建一个二叉树,并按从上到下、从左到右的顺序输出所有叶节点的编号。叶节点是指没有左孩子和右孩子的节点。

方法思路

  • 读取输入:首先读取输入数据,确定树的节点总数和每个节点的左、右孩子。
  • 构建树结构:使用数组来表示每个节点的左、右孩子和节点值。
  • 确定根节点:根节点是没有作为任何其他节点左或右孩子出现的节点。
  • 层次遍历:使用队列来进行层次遍历,检查每个节点是否为叶节点,并收集这些叶节点。
  • 输出结果:将收集到的叶节点编号按顺序输出。
  • 解决代码

    #include 
    #include
    #include
    using namespace std;struct Node { int data; int left; int right;};int main() { int n; cin >> n; Node nodes[n]; for (int i = 0; i < n; ++i) { char a, b; cin >> a >> b; nodes[i].left = (a != '-') ? (a - '0') : -1; nodes[i].right = (b != '-') ? (b - '0') : -1; nodes[i].data = i; } bool used[n] = {false}; for (int i = 0; i < n; ++i) { int left = nodes[i].left; int right = nodes[i].right; if (left != -1 && left < n) { used[left] = true; } if (right != -1 && right < n) { used[right] = true; } } int root = -1; for (int i = 0; i < n; ++i) { if (!used[i]) { root = i; break; } } queue
    q; vector
    result; q.push(root); while (!q.empty()) { int current = q.front(); q.pop(); if (nodes[current].left == -1 && nodes[current].right == -1) { result.push_back(current); } if (nodes[current].left != -1) { q.push(nodes[current].left); } if (nodes[current].right != -1) { q.push(nodes[current].right); } } if (!result.empty()) { cout << result[0]; for (int i = 1; i < result.size(); ++i) { cout << " " << result[i]; } } return 0;}

    代码解释

  • 读取输入:读取节点总数n,然后读取每个节点的左、右孩子信息,构建树结构。
  • 确定根节点:使用一个布尔数组标记每个节点是否被作为子节点使用,根节点是未被标记的节点。
  • 层次遍历:使用队列进行层次遍历,检查每个节点是否为叶节点,并将叶节点编号收集起来。
  • 输出结果:将收集到的叶节点编号按顺序输出,确保格式正确。
  • 这个方法确保了我们能够正确地构建二叉树,并按要求输出所有叶节点的编号。

    转载地址:http://jxaz.baihongyu.com/

    你可能感兴趣的文章
    OpenCV与AI深度学习 | 使用OpenCV检测并计算直线角度
    查看>>
    OpenCV与AI深度学习 | 使用OpenCV轮廓检测提取图像前景
    查看>>
    OpenCV与AI深度学习 | 使用Python和OpenCV实现火焰检测(附源码)
    查看>>
    OpenCV与AI深度学习 | 使用PyTorch进行小样本学习的图像分类
    查看>>
    OpenCV与AI深度学习 | 使用YOLO11实现区域内目标跟踪
    查看>>
    OpenCV与AI深度学习 | 使用YOLOv8做目标检测、实例分割和图像分类(包含实例操作代码)
    查看>>
    OpenCV与AI深度学习 | 使用单相机对已知物体进行3D位置估计
    查看>>
    OpenCV与AI深度学习 | 初学者指南 -- 什么是迁移学习?
    查看>>
    OpenCV与AI深度学习 | 十分钟掌握Pytorch搭建神经网络的流程
    查看>>
    OpenCV与AI深度学习 | 基于GAN的零缺陷样本产品表面缺陷检测
    查看>>
    OpenCV与AI深度学习 | 基于OpenCV和深度学习预测年龄和性别
    查看>>
    OpenCV与AI深度学习 | 基于OpenCV实现模糊检测 / 自动对焦
    查看>>
    OpenCV与AI深度学习 | 基于Python和OpenCV将图像转为ASCII艺术效果
    查看>>
    OpenCV与AI深度学习 | 基于PyTorch实现Faster RCNN目标检测
    查看>>
    OpenCV与AI深度学习 | 基于PyTorch语义分割实现洪水识别(数据集 + 源码)
    查看>>
    OpenCV与AI深度学习 | 基于YOLO11的车体部件检测与分割
    查看>>
    OpenCV与AI深度学习 | 基于YoloV11自定义数据集实现车辆事故检测(有源码,建议收藏!)
    查看>>
    OpenCV与AI深度学习 | 基于YOLOv8 + BotSORT实现球员和足球检测与跟踪 (步骤 + 源码)
    查看>>
    OpenCV与AI深度学习 | 基于YOLOv8实现高级目标检测和区域计数
    查看>>
    OpenCV与AI深度学习 | 基于YOLOv8的停车对齐检测
    查看>>