C/C++程序基础 (八)数据结构
- 非递归先序遍历
-
// 输出, 遍历左子树,遍历右子树
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;
}
}
}
-
- 非递归中序遍历
// 输出, 遍历左子树,遍历右子树
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;
}
}
}
- 非递归后序遍历
// 输出, 遍历左子树,遍历右子树
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);
}
}
}
}
- 二叉排序树:左<父<右
- 哈弗曼树
- 哈夫曼编码:带权路径最短
- 构建方法:从最远端构建
- 平衡二叉(搜索)树:每个节点的左右子树深度差的绝对值小于等于1。
- 一种实现:红黑树
- 基本失衡情况:左左(右旋),右右(左旋),左右,右左。
- 红黑树
- 节点:红色或黑色。根节点:黑色。叶节点:黑色。红色节点的孩子为黑色。根节点到其每个叶子节点的所有路径包含相同数目的黑色节点。
- 等待补充
- 完全二叉树和满二叉树
- 完全二叉树,集中在左边
- 满二叉树,没有叶子节点
C/C++程序基础 (八)数据结构的更多相关文章
- Java基础八--构造函数
Java基础八--构造函数 一.子父类中构造函数的特点 1.1 为什么在子类构造对象时,发现,访问子类构造函数时,父类也运行了呢? 原因是:在子类的构造函数中第一行有一个默认的隐式语句. super( ...
- JAVA并行程序基础
JAVA并行程序基础 一.有关线程你必须知道的事 进程与线程 在等待面向线程设计的计算机结构中,进程是线程的容器.我们都知道,程序是对于指令.数据及其组织形式的描述,而进程是程序的实体. 线程是轻量级 ...
- PHP 程序员学数据结构与算法之《栈》
“要成高手,必练此功”. 要成为优秀的程序员,数据结构和算法是必修的内容.而现在的Web程序员使用传统算法和数据结构都比较少,因为很多算法都是包装好的,不用我们去操心具体的实现细节,如PHP的取栈 ...
- Bootstrap <基础八>图片
Bootstrap 提供了三个可对图片应用简单样式的 class: .img-rounded:添加 border-radius:6px 来获得图片圆角. .img-circle:添加 border-r ...
- Java语言基础(八)
Java语言基础(八) 一.数学运算 + - * / % (1)凡是byte short char类型都按int类型的计算 看看上面的代码,为什么出错! 我已经将100转成byte类型,( ...
- ROS_Kinetic_12 ROS程序基础Eclipse_C++(三)usb camera
ROS_Kinetic_12 ROS程序基础Eclipse_C++(三)usb camera 软件包下载地址:https://github.com/bosch-ros-pkg/usb_cam 下载后, ...
- ROS_Kinetic_11 ROS程序基础Eclipse_C++(二)
ROS_Kinetic_11 ROS程序基础Eclipse_C++(二) 编写简单的Service和Client (C++): http://wiki.ros.org/cn/ROS/Tutorials ...
- ROS_Kinetic_10 ROS程序基础Eclipse_C++(一)
ROS_Kinetic_10 ROS程序基础Eclipse_C++(一) 编写简单的消息发布器和订阅器 (C++) http://wiki.ros.org/cn/ROS/Tutorials/Writi ...
- Java并发程序设计(二)Java并行程序基础
Java并行程序基础 一.线程的生命周期 其中blocked和waiting的区别: 作者:赵老师链接:https://www.zhihu.com/question/27654579/answer/1 ...
- 微信小程序基础
前言 什么是微信小程序,它是一种轻量级的APP,它与常规App来说,无需下载安装即可使用,它嵌于微信App中,要使用微信小程序你只需要搜索一下微信小程序的名称就好,如近期的"Google的画 ...
随机推荐
- TOMCAT热部署 catalina.home catalina.base
catalina.home 一台机器通常只有一个, 指向Tomcat的安装目录 catalina.base 一台机器可以启动多个Context, 每个Context对应一个catalina.base ...
- (转)Linux: dirname、basename命令详解
Linux: dirname.basename命令详解 原文:http://blog.sina.com.cn/s/blog_3f63916f010143vo.html 一.dirname指令 1.功能 ...
- Kotlin基础知识
1. 改进点/基础 //安全判空 val length = text?.length; //类型转换 if (object is Car) { var car = object as Ca } //操 ...
- Java规则引擎drools:drt动态生成规则并附上具体项目逻辑
一 整合 由于本人的码云太多太乱了,于是决定一个一个的整合到一个springboot项目里面. 附上自己的项目地址https://github.com/247292980/spring-boot 以整 ...
- xenserver 更新源
在xenserver上安装vnc软件时,报错 [root@cloud yum-3.4.3]# ./yummain.py install yumThere are no enabled repos.Ru ...
- KindEditor编辑器使用
KindEditor使用 1)kindeditor默认模式调用 <link rel="stylesheet" href="./KindEditor/themes/d ...
- ssm(Spring、Springmvc、Mybatis)实战之淘淘商城-第十天(非原创)
文章大纲 一.课程介绍二.单点登录系统分析三.单点登录系统代码实战四.项目源码与资料下载五.参考文章 一.课程介绍 一共14天课程(1)第一天:电商行业的背景.淘淘商城的介绍.搭建项目工程.Svn ...
- hibernate课程 初探单表映射3-5 hibernate增删改查
本节简介: 1 增删改查写法 2 查询load和查询get方法的区别 3 demo 1 增删改查写法 增加 session.save() 修改 session.update() 删除 session. ...
- python之其他模块的用法
1.时间模块 在Python中通常有三种表示时间的方式,分别是时间戳.元组.格式化的时间字符串. 时间模块的常用方法 time.sleep() #指定延迟时间 time.time() #当前时间的 ...
- 利用python进行简单的图片处理
python的 PIL模块是专门用来处理图片的模块,其功能可以说是非常强大了. 演示环境:win7 操作系统 安装python2.7以及指定的对应PIL模块 我这里有一个现成的PIL模块.本文的大部分 ...