1. 非递归先序遍历

    •   

      // 输出, 遍历左子树,遍历右子树
      void firstOrder(Node* root)
      {
      stack<Node*> leftNodes;
      Node* curr = root; // deal each node
      while(curr != NULL && !leftNodes.empty())
      {
      // deal with left subtree
      while(curr != NULL)
      {
      cout << curr -> data << " ";
      // store curr node for reading right subtree
      leftNodes.push(curr);
      curr = curr -> left;
      } // deal with right subtree
      if(!leftNodes.empty())
      {
      curr = leftNodes.top();
      leftNodes.pop(); curr = curr -> right;
      }
      }
      }
  2. 非递归中序遍历
    • // 输出, 遍历左子树,遍历右子树
      void middleOrder(Node* root)
      {
      stack<Node*> leftNodes;
      Node* curr = root; // deal each node
      while(curr != NULL && !leftNodes.empty())
      {
      // deal with left subtree
      while(curr != NULL)
      {
      // store curr node for reading right subtree
      leftNodes.push(curr);
      curr = curr -> left;
      } // deal with right subtree
      if(!leftNodes.empty())
      {
      curr = leftNodes.top();
      leftNodes.pop();
      // cout curr node
      cout << curr -> data << " "; curr = curr -> right;
      }
      }
      }

        

  3. 非递归后序遍历
    • // 输出, 遍历左子树,遍历右子树
      void lastOrder(Node* root)
      {
      stack<Node*> leftNodes;
      stack<bool> tags;
      bool curr_tag = true;
      Node* curr = root; // deal each node
      while(curr != NULL && !leftNodes.empty())
      {
      // deal with left subtree
      while(curr != NULL)
      {
      // store curr node for reading right subtree
      leftNodes.push(curr); // mark have not seen right nodes
      tags.push(false);
      curr = curr -> left;
      } // deal with right subtree
      if(!leftNodes.empty())
      {
      curr = leftNodes.top();
      curr_tag = tags.top();
      tags.pop(); if(curr_tag)
      {
      cout << curr -> data << " ";
      leftNodes.pop();
      // have already dealt right subtree
      p = NULL;
      }
      else
      {
      curr = curr -> right;
      // mark has dealt with rightsubtree
      tags.push(true);
      }
      }
      }
      }
  4. 二叉排序树:左<父<右
  5. 哈弗曼树
    • 哈夫曼编码:带权路径最短
    • 构建方法:从最远端构建
  6. 平衡二叉(搜索)树:每个节点的左右子树深度差的绝对值小于等于1。
    • 一种实现:红黑树
    • 基本失衡情况:左左(右旋),右右(左旋),左右,右左。
  7. 红黑树
    • 节点:红色或黑色。根节点:黑色。叶节点:黑色。红色节点的孩子为黑色。根节点到其每个叶子节点的所有路径包含相同数目的黑色节点。
    • 等待补充
  8. 完全二叉树和满二叉树
    • 完全二叉树,集中在左边
    • 满二叉树,没有叶子节点

C/C++程序基础 (八)数据结构的更多相关文章

  1. Java基础八--构造函数

    Java基础八--构造函数 一.子父类中构造函数的特点 1.1 为什么在子类构造对象时,发现,访问子类构造函数时,父类也运行了呢? 原因是:在子类的构造函数中第一行有一个默认的隐式语句. super( ...

  2. JAVA并行程序基础

    JAVA并行程序基础 一.有关线程你必须知道的事 进程与线程 在等待面向线程设计的计算机结构中,进程是线程的容器.我们都知道,程序是对于指令.数据及其组织形式的描述,而进程是程序的实体. 线程是轻量级 ...

  3. PHP 程序员学数据结构与算法之《栈》

    “要成高手,必练此功”.   要成为优秀的程序员,数据结构和算法是必修的内容.而现在的Web程序员使用传统算法和数据结构都比较少,因为很多算法都是包装好的,不用我们去操心具体的实现细节,如PHP的取栈 ...

  4. Bootstrap <基础八>图片

    Bootstrap 提供了三个可对图片应用简单样式的 class: .img-rounded:添加 border-radius:6px 来获得图片圆角. .img-circle:添加 border-r ...

  5. Java语言基础(八)

    Java语言基础(八) 一.数学运算  + - * /  % (1)凡是byte  short  char类型都按int类型的计算   看看上面的代码,为什么出错! 我已经将100转成byte类型,( ...

  6. ROS_Kinetic_12 ROS程序基础Eclipse_C++(三)usb camera

    ROS_Kinetic_12 ROS程序基础Eclipse_C++(三)usb camera 软件包下载地址:https://github.com/bosch-ros-pkg/usb_cam 下载后, ...

  7. ROS_Kinetic_11 ROS程序基础Eclipse_C++(二)

    ROS_Kinetic_11 ROS程序基础Eclipse_C++(二) 编写简单的Service和Client (C++): http://wiki.ros.org/cn/ROS/Tutorials ...

  8. ROS_Kinetic_10 ROS程序基础Eclipse_C++(一)

    ROS_Kinetic_10 ROS程序基础Eclipse_C++(一) 编写简单的消息发布器和订阅器 (C++) http://wiki.ros.org/cn/ROS/Tutorials/Writi ...

  9. Java并发程序设计(二)Java并行程序基础

    Java并行程序基础 一.线程的生命周期 其中blocked和waiting的区别: 作者:赵老师链接:https://www.zhihu.com/question/27654579/answer/1 ...

  10. 微信小程序基础

    前言 什么是微信小程序,它是一种轻量级的APP,它与常规App来说,无需下载安装即可使用,它嵌于微信App中,要使用微信小程序你只需要搜索一下微信小程序的名称就好,如近期的"Google的画 ...

随机推荐

  1. CentOS6.5安装MySQL5.7(也适合其他版本安装)

     1.查看是否已经安装过mysql或其依赖,若已装过要先将其删除,否则第4步使用yum安装时会报错: 方法一:yum list installed | grep mysql 方法二:rpm -qa | ...

  2. Angular学习笔记【ngx-bootstrap】中的 tabset

    <tabset class="tab-container tabbable-line"> <tab heading="{{l("MobileS ...

  3. 【补档】Pycharm的一些配置

    新建和创建文件就不必说了吧~ 运行这里原本是灰色的,我们点旁边的三角形 点绿色+号,python Name:随便写 Script:选择一个py文件~,然后OK,就可以运行了

  4. spark_load csv to hive via hivecontext

    //prepare csv year,make,model,comment,blank "2012","Tesla","S","N ...

  5. maven插件: shade, assembly

    shade插件的作用: 通过版本的exclution无法解决jar冲突的问题, 解决方案是把依赖的包打到本model的jar中,打包的时候由mvn plugin自动修改代码中的依赖jar包名 relo ...

  6. 图片的回显。js

    l  <tr><td></td> <td> <c:if test="${editVo.pic!=''}"><img ...

  7. linux上的shutdown命令

    定时关机:shutdown -r now 立刻重新开机 shutdown -h now 立刻关机 shutdown -k now 'Hey! Go away! now....' 发出警告讯息, 但没有 ...

  8. SpringBoot | 第七章:过滤器、监听器、拦截器

    前言 在实际开发过程中,经常会碰见一些比如系统启动初始化信息.统计在线人数.在线用户数.过滤敏高词汇.访问权限控制(URL级别)等业务需求.这些对于业务来说一般上是无关的,业务方是无需关系的,业务只需 ...

  9. Docker:安装部署RabbitMQ

    前言 今天原本想讲解SpringBoot集成RabbitMQ的,临近开始写时才发现家里的电脑根本没有安装RabbitMQ呀.这下只好利用已有的阿里云服务器,直接Docker安装一下了,顺道记录下,算是 ...

  10. spring技术小结

    1.DI和IOC 依赖注入(Dependency Injection)还是控制反转(Inversion of Conctrol) bean通过依赖注入,注册到spring容器里面.spring容器通过 ...