当前位置: 首页 > news >正文

【算法】二叉树的递归遍历

前序遍历

void preOrder(Node *node)
    {
        if(node != nullptr)
        {
            cout << node->data_ << " ";
            preOrder(node->left_);
            preOrder(node->right_);
        }
    }

中序遍历

void inOrder(Node *node)
    {
        if (node != nullptr)
        {
            inOrder(node->left_);
            cout << node->data_ << " ";
            inOrder(node->right_);
        }
    }

后序遍历

void postOrder(Node *node)
    {
        if (node != nullptr)
        {
            postOrder(node->left_);
            postOrder(node->right_);
            cout << node->data_ << " ";
        }
    }

层序遍历

递归实现求二叉树的层数,求以node为根节点的子树的高度

int level(Node* node)
    {
        if(node == nullptr)
        {
            return 0;
        }
        int left = level(node->left_);
        int right = level(node->right_);
        return left > right ? left + 1 : right + 1;
    }

递归求二叉树节点的个数

int number(Node *node)
    {
        if(node == nullptr)
        {
            return 0;
        }
        int left = number(node->left_);
        int right = number(node->right_);
        return left + right + 1;
    }
// 递归层数遍历
    void levelOrder()
    {
        int h = level();
        for(int i = 0; i < h; i++)
        {
            levelOrder(root_, i);
        }
    }
    void levelOrder(Node *node, int i)
    {
        if(node == nullptr)
        {
            return;
        }
        if(i == 0)
        {
            cout << node->data_ << " ";
            return;
        }
        levelOrder(node->left_, i - 1);
        levelOrder(node->right_, i - 1);
    }

相关文章:

  • 【Axure资料】110套优质可视化大屏模板+图表组件+科技感元件等
  • Filebeat收集nginx日志到elasticsearch,最终在kibana做展示。
  • 绪论数据结构基本概念(刷题笔记)
  • Docker数据管理,端口映射与容器互联
  • 华为hcia——Datacom实验指南——三层交换和ARP的工作原理
  • 【愚公系列】《AI Agent技术、应用与商业》003-Al Agent 的分类方式
  • 【从零开始学习计算机科学】计算机组成原理(七)存储器与存储器系统
  • 系统架构的评估的系统的质量属性
  • Go本地缓存设计与实现
  • [微服务设计]1_微服务
  • Liunx——动静态库
  • AXI接口总结
  • 蓝桥杯备赛-差分-推箱子
  • 虚幻基础:动画系统
  • 推荐一款好用在线免费软件工具箱-传道软件箱
  • PostgreSQL - Windows PostgreSQL 下载与安装
  • Facebook 与信息传播:塑造新闻和媒体的新生态
  • 前端计算精度保卫战:Vue3中big.js的加减乘除实战指南
  • 深度学习系列80:Pike-RAG解析
  • C#工业上位机实时信号边沿检测实现
  • “宝马女司机驾车拖行虐猫”引关注,海口警方介入调查
  • 广东茂名高州市山体滑坡已致3死1失联,搜救仍在继续
  • 高温最强时段来了!北方局地高温有明显极端性
  • 交响4K修复版《神女》昨晚上演,观众听到了阮玲玉的声音
  • 《缶翁的世界》首发:看吴昌硕等湖州籍书画家的影响
  • 陕西:未来一周高温持续,继续发布冬小麦干热风风险预警