• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > C++实现二叉树非递归遍历方法实例总结

C++实现二叉树非递归遍历方法实例总结

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了c++二叉树,c++二叉树的建立,二叉树的遍历算法c++,c++创建二叉树,c++实现二叉树等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

一般来说,二叉树的遍历是C++程序员在面试中经常考察的,其实前中后三种顺序的遍历都大同小异,自己模拟两个栈用笔画画是不难写出代码的。现举一个非递归遍历的方法如下,供大家参考。

具体代码如下:

class Solution {
public:
  vector<int> preorderTraversal(TreeNode *root) {
    vector<int> out;
    stack<TreeNode*> s;
    s.push(root);
    while(!s.empty() && root){
      TreeNode *node = s.top();
      out.push_back(node->val);
      s.pop();
      if(node->right) s.push(node->right);
      if(node->left) s.push(node->left);
    }
    return out;
  }
  vector<int> inorderTraversal(TreeNode *root) {
    stack<TreeNode *> s;
    vector<int> out;
    TreeNode *node = root;
    bool done = false;
    while(!done){
      if(node){
        s.push(node);
        node = node->left;
      }else {
        if(s.empty()) done = true;
        else{
          node = s.top();
          s.pop();
          out.push_back(node->val);
          node = node->right;
        }
      }
    }
    return out;
  }
  vector<int> postorderTraversal(TreeNode *root) {
    vector<int> out;
    stack<TreeNode*> s;
    TreeNode* node = root;
    s.push(node);
    while(!s.empty()&&node){
      node = s.top();
      out.push_back(node->val);
      s.pop();
      if(node->left) s.push(node->left);
      if(node->right)s.push(node->right);
    }
    reverse(out.begin(),out.end());
    return out;
  }
};

</div>

希望本文所述对大家的C++算法学习有所帮助。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • C++使用递归和非递归算法实现的二叉树叶子节点个数计算方法
  • C++基于递归和非递归算法求二叉树镜像的方法
  • C++将二叉树转为双向链表及判断两个链表是否相交
  • C++实现查找二叉树中和为某一值的所有路径的示例
  • C++非递归建立二叉树实例
  • C++实现二叉树非递归遍历方法实例总结
  • c++实现二叉查找树示例
  • C++二叉树结构的建立与基本操作
  • c++二叉树的几种遍历算法

相关文章

  • 2017-05-28详解state状态模式及在C++设计模式编程中的使用实例
  • 2017-05-28c++利用windows函数实现计时示例
  • 2017-05-28基于C语言中段错误的问题详解
  • 2017-05-28详解C++编程中的单目运算符重载与双目运算符重载
  • 2017-05-28斐波那契数列 优化矩阵求法实例
  • 2017-05-28Cocos2d-x学习笔记之Hello World源码分析
  • 2017-05-28浅析C语言中的sizeof
  • 2017-05-28C语言中设置用户识别码的相关函数的简单讲解
  • 2017-05-28C语言中system()函数的用法总结
  • 2017-05-28深入串的模式匹配算法(普通算法和KMP算法)的详解

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • 浅谈C++内存分配及变长数组的动态分配
    • 解析在WTL下使用双缓冲的实现方法
    • 详解安卓系统中的Android.mk文件
    • c语言实现的带通配符匹配算法
    • 详解C语言中const关键字的用法
    • C++处理键盘输入的方法
    • C语言fscanf和fprintf函数的用法详解(格式化读写文件)
    • 一般函数指针和类的成员函数指针深入解析
    • VC中实现GB2312、BIG5、Unicode编码转换的方法
    • 详细解析命令行的getopt_long()函数

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有