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

力扣 二叉树遍历 中序/前序/后序(递归和迭代版)

给定一个二叉树的根节点 root ,返回 它的 中序 遍历 。

示例 1:

输入:root = [1,null,2,3]
输出:[1,3,2]

示例 2:

输入:root = []
输出:[]

示例 3:

输入:root = [1]
输出:[1]

提示:

  • 树中节点数目在范围 [0, 100] 内
  • -100 <= Node.val <= 10

代码:中序用递归来实现

class Solution {

public:

    void inorder(TreeNode *root,vector<int>& res){

        if(!root){

            return;

        }

        inorder(root->left,res);

        res.push_back(root->val);

        inorder(root->right,res);

    }

    vector<int> inorderTraversal(TreeNode* root) {

        vector<int> res;

        inorder(root,res);

        return res;

    }

};

前序迭代版:用栈来实现

class Solution {

public:

    vector<int> preorderTraversal(TreeNode* root) {

        vector<int> res;

        stack<TreeNode *> s;

        s.push(root);

        while(!s.empty()){

            TreeNode *tmp = s.top();

            s.pop();

            if(!tmp) continue;

            res.push_back(tmp->val);

            s.push(tmp->right);

            s.push(tmp->left);

        }

        return res;

   }

};

前序遍历递归版:

class Solution {

public:

    void frontorder(TreeNode *root,vector<int>& res)

    {

        if(!root)return;

        res.push_back(root->val);

        frontorder(root->left,res);

        frontorder(root->right,res);

    }

    vector<int> preorderTraversal(TreeNode* root) {

        vector<int> res;

        frontorder(root,res);

        return res;

   }

};

后序递归版:

class Solution {

public:

    void beheadorder(TreeNode *root,vector<int>& res)

    {

        if(!root) return;

        beheadorder(root->left,res);

        beheadorder(root->right,res);

        res.push_back(root->val);

    }

    vector<int> postorderTraversal(TreeNode* root) {

        vector<int> res;

        beheadorder(root,res);

        return res;

    }

};

http://www.dtcms.com/a/311983.html

相关文章:

  • dbt中多源数据的处理
  • 混合嵌入与置信度增强:新一代RAG技术如何提升LLM性能
  • 1.6 vue 监听
  • JavaScript 原始值与引用值
  • SQL语言学习(group by,having)
  • PyTorch 中 Tensor 统计学函数及相关概念
  • 基于单片机一氧化碳CO检测/煤气防中毒检测报警系统
  • OneCode 3.0智能分页拦截器深度解析:从拦截机制到性能优化
  • 轨道追逃博弈仿真
  • 输电线路建模与电力负荷特性详解(含等值模型与曲线分析)
  • Vue 详情模块 4
  • SQL语言学习(JOIN)
  • Orange的运维学习日记--25.Linux文件系统基本管理
  • 使用xshell连接远程腾讯云服务器,报错:Xshell Socket error Event: 32 Error: 10053
  • 智能图书馆管理系统开发实战系列(五):前后端集成 - koffi调用与接口设计
  • 用resmon搜索某文件被未知程序占用而无法删除
  • 第15届蓝桥杯Python青少组_省赛_中/高级组2024年8月真题
  • Java,八股,cv,算法——双非研0四修之路day23
  • SpringBoot 信用卡检测、OpenAI gym、OCR结合、DICOM图形处理、知识图谱、农业害虫识别实战
  • 博客|基于Springboot的个人博客系统设计与实现(源码+数据库+文档)
  • 占道经营识别漏检率↓76%:陌讯动态场景适配算法实战解析
  • 区分「尊重」和「顺从」
  • FastAPI入门:响应模型
  • 如何分析Linux内存性能问题
  • Windows字体simsum.ttf的安装与Python路径设置指南
  • junit中@InjectMocks作用详解
  • wgd v1.1.2 安装与使用-生信工具056
  • Java 字符串常量池 +反射,枚举和lambda表达式
  • 【数据结构】栈的顺序存储(整型栈、字符栈)
  • Postman四种请求教程