前言

为什么会有线索化二叉树呢?

是这样子的,二叉树呢,比如有n个节点,那么就有n+1个空指针域。

这个是怎么来的呢?比如我们假如一个节点都有左子树和右子树,那么就有2n个节点。

但是我们发现连接我们节点的一共有n-1个(要把n个节点串起来),那么就等于2n-(n-1)=n+1。

那么如何利用这些空间?

假如中序遍历如下:

{8,3,10,1,6,14}

那么如果3的右节点为空,就指向它的后驱节点,也就是10。

如果3的左节点为空,那么就指向它的前驱节点,也就是8。

以此类推,8的前驱节点为空,如果左节点为空,那么就是空。

职业盗图:

正文

创建节点模型:

public class ThreadedHeroNode
{
private int no; private string name; private ThreadedHeroNode left; private ThreadedHeroNode right;
//0 表示左子树,1表示后继节点
private int leftType;
//0 表示右子树,1表示后继节点
private int rightType; public int getLeftType()
{
return leftType;
} public void setLeftType(int leftType)
{
this.leftType = leftType;
} public int getRightType()
{
return rightType;
} public void setRightType(int rightType)
{
this.rightType = rightType;
} public ThreadedHeroNode(int no, string name)
{
this.no = no;
this.name = name;
} public int getNo()
{
return no;
}
public void setNo(int no)
{
this.no = no;
} public String getName()
{
return name;
}
public void setName(String name)
{
this.name = name;
}
public ThreadedHeroNode getLeft()
{
return left;
}
public void setLeft(ThreadedHeroNode left)
{
this.left = left;
}
public ThreadedHeroNode getRight()
{
return right;
}
public void setRight(ThreadedHeroNode right)
{
this.right = right;
}
public override string ToString()
{
return "姓名:" + name + "编号:" + no;
} public void record()
{
Console.WriteLine("查找步骤为:名字" + this.name + " 编号:" + this.no);
}
}

创建树模型:

public class ThreadedBinaryTree
{
private ThreadedHeroNode root; private ThreadedHeroNode pre; public void setRoot(ThreadedHeroNode root)
{
this.root = root;
} //中序遍历线索化二叉树
public void threadedList()
{
ThreadedHeroNode node = root;
while (node!=null)
{
//判断是否是
while (node.getLeftType() == 0)
{
node = node.getLeft();
}
Console.WriteLine(node);
while (node.getRightType() == 1)
{
node = node.getRight();
Console.WriteLine(node);
}
node=node.getRight();
}
} public void threadedNodes()
{
threadedNodes(root);
} public void threadedNodes(ThreadedHeroNode node)
{
if (node == null)
{
return;
}
//线索化左子树
threadedNodes(node.getLeft());
if (node.getLeft() == null)
{
node.setLeft(pre);
node.setLeftType(1);
}
if (pre != null&& pre.getRight() == null)
{
pre.setRight(node);
pre.setRightType(1);
}
pre = node;
//线索化右子树
threadedNodes(node.getRight());
}
}

测试:

static void Main(string[] args)
{
//测试一把中序线索二叉树的功能
ThreadedHeroNode root = new ThreadedHeroNode(1, "tom");
ThreadedHeroNode node2 = new ThreadedHeroNode(3, "jack");
ThreadedHeroNode node3 = new ThreadedHeroNode(6, "smith");
ThreadedHeroNode node4 = new ThreadedHeroNode(8, "mary");
ThreadedHeroNode node5 = new ThreadedHeroNode(10, "king");
ThreadedHeroNode node6 = new ThreadedHeroNode(14, "dim"); //二叉树,后面我们要递归创建, 现在简单处理使用手动创建
root.setLeft(node2);
root.setRight(node3);
node2.setLeft(node4);
node2.setRight(node5);
node3.setLeft(node6); //测试中序线索化
ThreadedBinaryTree threadedBinaryTree = new ThreadedBinaryTree();
threadedBinaryTree.setRoot(root);
threadedBinaryTree.threadedNodes();
//当线索化二叉树后,能在使用原来的遍历方法
Console.WriteLine("使用线索化的方式遍历 线索化二叉树");
threadedBinaryTree.threadedList(); // 8, 3, 10, 1, 14, 6
Console.ReadKey();
}

测试结果:

重新整理数据结构与算法(c#)—— 线索化二叉树[二十]的更多相关文章

  1. 数据结构与算法---线索化二叉树(Threaded BinaryTree)

    先看一个问题 将数列 {1, 3, 6, 8, 10, 14  } 构建成一颗二叉树 问题分析: 当我们对上面的二叉树进行中序遍历时,数列为 {8, 3, 10, 1, 6, 14 } 但是 6, 8 ...

  2. C#数据结构-线索化二叉树

    为什么线索化二叉树? 对于二叉树的遍历,我们知道每个节点的前驱与后继,但是这是建立在遍历的基础上,否则我们只知道后续的左右子树.现在我们充分利用二叉树左右子树的空节点,分别指向当前节点的前驱.后继,便 ...

  3. 线索化二叉树的构建与先序,中序遍历(C++版)

    贴出学习C++数据结构线索化二叉树的过程, 方便和我一样的新手进行测试和学习 同时欢迎各位大神纠正. 不同与普通二叉树的地方会用背景色填充 //BinTreeNode_Thr.h enum Point ...

  4. 后序线索化二叉树(Java版)

    前面介绍了前序线索化二叉树.中序线索化二叉树,本文将介绍后序线索化二叉树.之所以用单独的一篇文章来分析后序线索化二叉树,是因为后序线索化二叉树比前序.中序要复杂一些:另外在复习线索化二叉树的过程中,大 ...

  5. JAVA递归实现线索化二叉树

    JAVA递归实现线索化二叉树 基础理论 首先,二叉树递归遍历分为先序遍历.中序遍历和后序遍历. 先序遍历为:根节点+左子树+右子树 中序遍历为:左子树+根节点+右子树 后序遍历为:左子树+右子树+根节 ...

  6. YTU 3026: 中序线索化二叉树

    原文链接:https://www.dreamwings.cn/ytu3026/2896.html 3026: 中序线索化二叉树 时间限制: 1 Sec  内存限制: 128 MB 提交: 9  解决: ...

  7. 图解前序遍历线索化二叉树,前序线索二叉树遍历,C\C++描述

    body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...

  8. 图解中序遍历线索化二叉树,中序线索二叉树遍历,C\C++描述

    body, table{font-family: 微软雅黑; font-size: 13.5pt} table{border-collapse: collapse; border: solid gra ...

  9. 整理一下CSS最容易躺枪的二十规则,大家能躺中几条?

    整理一下CSS最容易躺枪的二十规则,大家能躺中几条? 转载:API中文网 一.float:left/right 或者 position: absolute 后还写上 display:block? 二. ...

  10. 重新整理数据结构与算法(c#)—— 图的深度遍历和广度遍历[十一]

    参考网址:https://www.cnblogs.com/aoximin/p/13162635.html 前言 简介图: 在数据的逻辑结构D=(KR)中,如果K中结点对于关系R的前趋和后继的个数不加限 ...

随机推荐

  1. Linux操作系统加固建议

    1.1.1 口令锁定策略 1.执行备份 (1).redhat执行备份: #cp -p /etc/pam.d/system-auth /etc/pam.d/system-auth_bak (2).SUS ...

  2. 一文搞懂如何自己写一个Python库

    一文搞懂如何自己写一个Python库 你是否曾想过为自己的Python项目编写一个库,以便在不同项目中重复使用代码? 并且能在PyPI仓库中发布,并通过pip install 库名来安装使用 编写Py ...

  3. PaddleOCR 服务化部署(基于PaddleHub Serving)

    最近用到百度飞桨的 PaddleOCR,研究了一下PaddleOCR的服务化部署,简单记录一些部署过程和碰到的问题. 基础环境 paddlepaddle 2.5.2 python 3.7 paddle ...

  4. Git修改最近一次提交的日志信息

    一.问题由来 当前自己所在的项目组中,每次发完一个版本后,就需要创建个人新版本的git提交凭证,其实就是系统自动 生成的一串编码,如果没有这个凭证,代码是提交不了的,这是公司制定的开发规范之一.这两天 ...

  5. Android 语音播放(文字TTS)

    原文地址:Android 语音播放(文字TTS) | Stars-One的杂货小窝 基于Google内置的TTS引擎,封装了个语音播放的工具类 使用 //初始化 SpeechService.init( ...

  6. 🚀🚀🚀Elasticsearch 主副分片切换过程中对业务写入有影响吗

    先说下结论,只要集群中的工作节点过半,有候选的master节点,挂掉的节点中不同时包含索引的主分片和副分片,那么ES是可以做到让业务无感知的进行主副分片切换的. 蓝胖子会先讲解下ES集群写入文档的原理 ...

  7. Spring Boot学习日记1

    今天了解了springboot是什么,起源和历史 Spring是一个开源框架,2003 年兴起的一个轻量级的Java 开发框架,作者:Rod Johnson . Spring是为了解决企业级应用开发的 ...

  8. 自定义MarkupExtension的学习,以及WPF中Combobox绑定枚举类型

    我们上一期讲到ComBobox绑定数据,https://www.cnblogs.com/guchen33/p/17630808.html 这次我们简单化一下, 正常来讲WPF中绑定不了枚举的像这样 / ...

  9. R语言安装教程

    R 语言官方网站:The Comprehensive R Archive Network 官方镜像站列表:CRAN - Mirrors 一.官网下载R安装包 下载地址为:Index of /bin 进 ...

  10. vue,vuex,element实现无限tab页效果

    直接撸代码 ?满足你 码云地址 效果图 tab页由来 甲方爸爸的更改需求,无力反抗 分析代码 懒的写,直接撸就行 参考文章 点我