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. ACM-ICPC 2018 徐州赛区网络预赛-G Trace(线段树的应用

    Problem:Portal传送门 Problem:Portal传送门  原题目描述在最下面.  我理解的题意大概是:有n次涨潮和退潮,每次的范围是个x×y的矩形,求n次涨退潮后,潮水痕迹的长度.   ...

  2. OpenCV3的配置(VS2015)

    1:首先下载和解压到给定的目录 2:设置环境变量...\build\x64\vc14\bin 3:打开VS,新建一个项目,再添加一个代码,刚开始当然是报错的 #include<opencv2\o ...

  3. redis数据类型--个人常规用法

    一.String 1.可以容纳最高512M的value. 2.经常用于通过expire来实现自动过期的一些值,直接通过setex 来. 3.通过incrby的方式,来实现value值得增长. 4.执行 ...

  4. Zookeeper问题汇总

    1. 遗留问题 a). zookeeper集群如何保证请求的均匀分布? 2. ZK概念澄清 2.1 ZK节点类型 CreateMode.PERSISTENT //持久节点,该节点客户端断开后不会删除 ...

  5. Maven的学习资料收集--(一)环境搭建

    这几天在做项目的时候用到了maven,但是自己没有从来没有接触过,所以咋网上找资料,终于找到了一下的资料,这个是别人总结的,我只是转载过来积累.请尊重原创. 官网地址:http://maven.apa ...

  6. 利用XML序列化和Asp.Net Web缓存实现站点配置文件

    我们经常会遇到这样的场景: 今天来了个业务,需要加一个字段,但是考虑的以后可能有变动,需要配成“活”的. 一般最初的做法就是加一个配置到Web.Config文件的AppSettings中去.但是这样有 ...

  7. NumPy(数组计算)

    一.介绍 NumPy是高性能科学计算和数据分析的基础包.它是pandas等其他各种工具的基础. 1.主要功能 1)ndarray,一个多维数组结构,高效且节省空间2)无需循环对整组数据进行快速运算的数 ...

  8. maven 搭建springMvc+mybatis

    1.在resource文件夹下创建Configure.xml <?xml version="1.0" encoding="UTF-8"?> < ...

  9. 前端js优化方案(一)

    最近在读<高性能javascript>,在这里记录一下读后的一些感受,顺便加上自己的一些理解,如果有兴趣的话可以关注的我的博客http://www.bloggeng.com/,我会不定期发 ...

  10. arcgis textsymbol overlap

    arcgis  textsymbol   overlap   textsymbol  重叠的问题  du?de?  duration??    arcgis  for  javascript 如何避免 ...