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的画 ...
随机推荐
- jquery 更新值。。vue 如何监听?
size.val(5); // 改变值 //触发 input 事件 ie11 下不能用 size[0].dispatchEvent(new Event('input')); 有些浏览器 不支持.. ...
- 牛客网训练赛26D(xor)
题目链接:https://www.nowcoder.com/acm/contest/180/D 线性基的学习:https://www.cnblogs.com/vb4896/p/6149022.html ...
- Oracle之rman数据库在非归档模式下的备份和恢复
1.数据库在非归档模式下的备份 SQL> archive log list;数据库日志模式 非存档模式自动存档 禁用存档终点 USE_DB_RECOVERY_FILE_DEST最早的联机日志序列 ...
- .net 中的托管与非托管
托管代码 托管代码就是Visual Basic .NET和C#编译器编译出来的代码.编译器把代码编译成中间语言(IL),而不是能直接在你的电脑上运行的机器码.中间语言被封装在一个叫程序集(assemb ...
- 使用pycharm 运行python的django项目时报错“Quit the server with CTRL-BREAK.”
Quit the server with CTRL-BREAK.Error: [Errno 10013] 1昨晚测试时还好好的,怎么突然出现这个错误,于是GOOLE,找到个帖子说可能是端口占用了,用工 ...
- Struts2初级篇(HelloWorld)
Struts2的工作流程: 从一个高水平角度看,Struts2 是一个MVC拉动的(或MVC2)框架,Struts2 的模型-视图-控制器模式是通过以下五个核心部分进行实现的: 操作(Actions) ...
- mybatis-分页和缓存
1.分页 1.1在dao接口中配置分页参数: package com.java1234.mappers; import java.util.List;import java.util.Map; imp ...
- 慎用python的pop和remove方法
申明:转载请注明出处!!! Python关于删除list中的某个元素,一般有两种方法,pop()和remove(). 如果删除单个元素,使用基本没有什么问题,具体如下. 1.pop()方法,传递的是待 ...
- 联动选择通过ajax获取选择对应的数据
网站有时候需要这种联动然后获取到想对应的数据 思路: 这种的话就是你每次选择哪一个就将这个设置一个标注 表示你现在选择的是哪一个 然后每选择一次就进行一次ajax查询,ajax里面有一个data里面添 ...
- coursera_ML_1
机器学习定义: A computer program is said to leran from experience E with respect to some task T and some ...