中序遍历线索化二叉树以及最终实现结果

中序遍历线索化二叉树思路分析

void InOrderCuleTree(node* root)
{
    if(root == null)
    {
        cout<<结点为空<<endl ;
        return;
    }
    node* tmpnode = root;
    
    while(tmpnode不为空)
    {
//先找到左边的第一个线索化节点,并进行打印
         while(tmpnode.lefttag!=1)
        {
            tmpnode = tmpnode.rightchild
        }
//打印结点数据
        cout<<"此时输出的是第一个结点"<<endl ;

如果该节点右子节点也是线索化节点,则打印它
//一直是就一直打印
        while(tmpnode.righttag == 1)
        {
            cout<<tmpnode.rightchild.data;
            tmpnode = tmpnode.rightchild;
        }
        tmpnode = tmpnode.rightchild;//走到这步是因为下一个结点并不是后继结点,因此要继续寻找上一个结点的后续结点。
    }
   
    
    
}

代码实现

#include<iostream>
#include<string.h>

using namespace std;

typedef int datatype;
struct BitNode
{
	datatype Data;
	struct BitNode* leftChild;
	struct BitNode* rightChild;
	int lefttag;
	int righttag;
};
#pragma region 中序递归线索化
BitNode* previous = NULL;
void PreOrderIterative(BitNode* root)
{
	if (root == NULL)
	{
		return;
	}
	BitNode* tmpnode = NULL;
	tmpnode = root;
	PreOrderIterative(tmpnode->leftChild);
	if (tmpnode->leftChild == NULL)
	{
		tmpnode->leftChild = previous;//左孩子指向前驱
		tmpnode->lefttag = 1;
	}
	/*如果想指向后继,必须返回到前一层结点 才能让当前层的*/
	if (previous != NULL && previous->rightChild == NULL)
	{
		previous->rightChild = tmpnode;
		previous->righttag = 1;
	}
	previous = tmpnode;
	PreOrderIterative(tmpnode->rightChild);
}
#pragma endregion
#pragma region 中序遍历线索化二叉树
void PreOrderCuleTree(BitNode* root)
{
	if (root == NULL)
	{
		cout << "结点为空!" << endl;
		return;
	}
	BitNode* tmpnode = NULL;
	tmpnode = root;
	while (tmpnode != NULL)
	{
		while (tmpnode!=NULL)
		{
			/*找到左边的第一个线索化的结点*/ 
			while (tmpnode->lefttag != 1)
			{
				tmpnode = tmpnode->leftChild;
			}
			/*输出该结点的数据*/
			cout << tmpnode->Data << endl;
			/*如果该结点的右子树结点一直是线索化结点,那么就需要一直打印 因为都是串联的*/
			while (tmpnode->righttag == 1)
			{
				cout << tmpnode->rightChild->Data << endl;
				tmpnode = tmpnode->rightChild;
			}
			/*走到这步表示 接下来的结点非线索化结点 需要跳过 寻找该节点的左结点*/
			tmpnode = tmpnode->rightChild;
		}
	}
		
}
#pragma endregion
#pragma region 主实现函数

int main(void)
{
	BitNode* n1 = new BitNode();
	BitNode* n3 = new BitNode();
	BitNode* n6 = new BitNode();
	BitNode* n8 = new BitNode();
	BitNode* n10 = new BitNode();
	BitNode* n14 = new BitNode();
	n1->Data = 1, n3->Data = 3, n6->Data = 6, n8->Data = 8, n10->Data = 10,n14->Data = 14;
	n1->leftChild = n3;
	n1->rightChild =n6;
	n3->leftChild = n8;
	n3->rightChild = n10;
	n6->leftChild = n14;
	PreOrderIterative(n1);
	PreOrderCuleTree(n1);
	return 0;
}

最终实现结果:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/373872.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

物联网ARM开发-STM32之RTC浅谈

RTC 一.RTC简单介绍 RTC好比我们用来记录时间的一个钟表&#xff0c;他里面有年月日&#xff0c;还可以记录星期&#xff0c;小时&#xff0c;分钟等。是Real Time Clock的缩写&#xff0c;译为实时时钟&#xff0c;本质上是一个独立的定时器。 1. 1 与通用定时器的区别 可以…

Java空指针异常报错java.lang.NullPointerException介绍与解决

java.lang.NullPointerException 出现的几种原因&#xff1a; 字符串变量未初始化接口类型的对象没有用具体的类初始化&#xff0c;比如&#xff1a; Map map // 会报错 Map map new Map(); //则不会报错了当一个对象的值为空时&#xff0c;你没有判断为空的情况。字符串与文…

数据结构|对称矩阵压缩存储的下标公式推导|如何求对称矩阵压缩存储对应的一维数组下标

因为考试的时候可能会给很多情况的变式题&#xff0c;所以要会推导而不是背公式&#xff0c;情况变了&#xff0c;公式就不管用了。 行优先、只存储主对角线下三角区&#xff1a; 矩阵下标 ai,j(i>j)->一维数组下标 B[k] 按照行优先的原则&#xff0c;确定 ai,j 是一维数…

Go 中如何检查文件是否存在?可能产生竞态条件?

嗨&#xff0c;大家好&#xff01;本文是系列文章 Go 技巧第十三篇&#xff0c;系列文章查看&#xff1a;Go 语言技巧。 Go 中如何检查文件是否存在呢&#xff1f; 如果你用的是 Python&#xff0c;可通过标准库中 os.path.exists 函数实现。遗憾的是&#xff0c;Go 标准库没有…

Python:批量url链接保存为PDF

我的数据是先把url链接获取到存入excel中&#xff0c;后续对excel做的处理&#xff0c;各位也可以直接在程序中做处理&#xff0c;下面就是针对excel中的链接做批量处理 excel内容格式如下&#xff08;涉及具体数据做了隐藏&#xff09; 标题文件链接文件日期网页标题1http://…

蓝桥杯Web应用开发-浮动与定位

浮动与定位 浮动布局比较灵活&#xff0c;不易控制&#xff0c;而定位可以控制元素的过分灵活性&#xff0c;给元素一个具体的空间和精确的位置。 浮动 我们使用 float 属性指定元素沿其容器的左侧或右侧放置&#xff0c;浮动布局常见取值如下&#xff1a; • left&#xff0…

2024美赛数学建模C题完整论文教学(含十几个处理后数据表格及python代码)

大家好呀&#xff0c;从发布赛题一直到现在&#xff0c;总算完成了数学建模美赛本次C题目Momentum in Tennis完整的成品论文。 本论文可以保证原创&#xff0c;保证高质量。绝不是随便引用一大堆模型和代码复制粘贴进来完全没有应用糊弄人的垃圾半成品论文。 C论文共49页&…

Java设计模式-责任链模式

责任链模式 一、概述二、结构三、案例实现四、优缺点五、源码解析 一、概述 在现实生活中&#xff0c;常常会出现这样的事例&#xff1a;一个请求有多个对象可以处理&#xff0c;但每个对象的处理条件或权限不同。例如&#xff0c;公司员工请假&#xff0c;可批假的领导有部门…

spring boot学习第十篇:elastic search必须使用用户名密码授权后才能访问、在java代码中操作索引

前提条件&#xff1a;安装好了elastic search服务&#xff0c;参考&#xff1a;elastic search入门_ubuntu elasticsearch 密码-CSDN博客 1、配置elastic search必须使用用户名密码授权才能访问 1.1开启x-pack验证 修改config目录下面的elasticsearch.yml文件&#xff0c;添…

如何使用 sqlalchemy declarative base 多层次继承

在SQLAlchemy中&#xff0c;通过declarative_base创建的基类可以通过多层次的继承建立继承关系。这允许你在数据库中创建具有继承结构的表。在我使用某数据库做中转的时候&#xff0c;经常会遇到各种各样的问题&#xff0c;例如下面的问题&#xff0c;通过记录并附上完美的解决…

C语言—自定义函数的传值调用和传址调用

不多废话&#xff0c;先说函数定义&#xff0c;分为两种&#xff1a; 库函数&#xff1a;C语言内部提供的函数&#xff1b;自定义函数&#xff1a;自己写的函数。 本文主要讲自定义函数&#xff0c;也就是如何自己实现函数的编写。 自定义函数&#xff0c;包括&#xff1a;函…

【Qt学习笔记】(三)常用控件(持续更新)

Qt 常用控件 1 控件概述2 QWidget 控件核心属性2.1 enabled2.2 geometry2.3 window frame 的影响2.4 windowTitle2.5 window Icon2.6 windowOpacity2.7 cursor2.8 font2.9 toolTip2.10 focusPolicy2.11 stylesheet 1 控件概述 Widget是Qt中的核心概念英文原义是"小部件&q…

算法学习——LeetCode力扣数组篇

算法学习——LeetCode力扣数组篇 704. 二分查找 704. 二分查找 - 力扣&#xff08;LeetCode&#xff09; 描述 给定一个 n 个元素有序的&#xff08;升序&#xff09;整型数组 nums 和一个目标值 target &#xff0c;写一个函数搜索 nums 中的 target&#xff0c;如果目标值…

C语言-4

排序算法简介 /*学习内容&#xff1a;冒泡排序&#xff08;最基本的排序方法&#xff09;选择排序&#xff08;冒泡的优化&#xff09;插入排序&#xff08;在合适的位置插入合适的数据&#xff09; *//*排序分类&#xff1a;1.内部排序待需要进行排序的数据全部存放到内存中&…

wins 安装 tensorflow keras

1.python版本 python版本3.12&#xff0c;安装tensorflow会报错&#xff1a; 经过多次实验&#xff0c;使用的python版本是3.9.0 2.安装tensorflow a. pip install --trusted-host http://mirrors.aliyun.com/pypi/simple/ tensorflow2.6.0 速度有点慢&#xff0c;半个多小…

前端实现搜索框筛选

效果图 页面解析 是一个input输入框和一个button按钮组成输入框查询 内容是一个折叠面板 html代码 <div class"left-content-box"><div class"colum-search"><el-input v-model"columKey" clearable placeholder"请输入关…

SpringBoot+Druid并开启监控页面

介绍 Druid 是一个开源的数据库连接池项目&#xff0c;由阿里巴巴集团开发并贡献给开源社区。它在Java领域中以其高性能、强大功能和易用性著称&#xff0c;是Java应用中广泛使用的数据库连接池组件之一。 Druid 的主要特点包括&#xff1a;   高性能与低延迟&#xff1a; Dr…

CRM的线索管理功能是什么?如何帮助企业实现业绩增长?

随着“以客户为中心”观念的逐渐普及&#xff0c;销售团队的客户比过去更复杂&#xff0c;交易周期更久&#xff0c;竞争也更激烈。假如没有明确的销售计划&#xff0c;团队可能陷入混乱&#xff0c;最后导致客户&公司之间的负面结果。在这种情况下&#xff0c;人工智能驱动…

小白Linux学习笔记--进程管理

进程管理 文章目录 进程管理进程pstree 命令静态查看进程信息pspgrep 动态查看进程信息top 终端提示符不显示停止进程killallpkillxkill进程优先级指定优先级调整优先级 前后台作业进程管理课后作业 进程 进程&#xff1a; 运行在内存中程序实例 , 进程是程序运行的一种状态 , …

EasyExcel分页上传数据

EasyExcel分页上传数据 一、实例 controller上传入口 PostMapping("/upload")ResponseBodyLog(title "导入工单", businessType BusinessType.IMPORT)public AjaxResult uploadFile(HttpServletRequest request, MultipartFile files) throws Exceptio…