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. (二)异步解决方案之callback

    回调定义 就是一个函数里面使用 作为参数的函数. Function1(Function2) { Function2(); }; 同步调用 - 老实说,这和我们 不将代码封装成 函数没有差别 也就是说 ...

  2. Linux--2 Linux之文档与目录结构、shell基本命令

    一.Linux之文档与目录结构 1.Linux之文档与目录结构 Linux目录结构的组织形式和Windows有很大的不同.Linux没有“盘(如C盘.D盘.E盘)”的概念,而是建立一个根"/ ...

  3. 自定义ClassLoader加载class文件

    package com.yd.wmsc.util; public class Test { public void say(){ System.out.println("Say Hello& ...

  4. LeetCode 101 Symmetric Tree 判断一颗二叉树是否是镜像二叉树

    Given a binary tree, check whether it is a mirror of itself (ie, symmetric around its center).For ex ...

  5. docker nginx部署.net core后端站点和angular前端站点

    首先声明,服务器是linux 版本是ubuntu server 18.04,不是windows server.windows server 2016放弃治疗了,2019可能会有改善,不过云厂商的公共镜 ...

  6. Unity UGUI暂停按钮切换图片代码

    using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEngine.UI; ...

  7. (转)Linux最常用指令及快捷键 Linux学习笔记

    Linux最常用指令及快捷键 Linux学习笔记 原文:http://blog.csdn.net/yanghongche/article/details/50827478 [摘自 鸟叔的私房菜]--转 ...

  8. Practice encryptedblobstore

    C++ BlobStore 使用范例(C++伪代码) 一个可能的接口设计示例(C++) Java BlobStore 使用范例(Java伪代码) 一个可能的接口设计示例(Java) 一个基于Key/V ...

  9. Oracle单行函数。。。

    单行函数 --字符函数--1.ASCII 返回与指定的字符对应的十进制数;select ascii('A') A,ascii('a') a,ascii('0') zero,ascii(' ') spa ...

  10. sql 删除字段 出错

    1. 删除字段:   ALTER TABLE TALE_NAME DROP COLUMN nn;   2.报错: 消息 5074,级别 16,状态 1,第 1 行对象'DF__WorkOrder__I ...