二叉树应用之线索化
发布日期:2021-06-29 15:42:45 浏览次数:2 分类:技术文章

本文共 1526 字,大约阅读时间需要 5 分钟。

线索二叉树

       对二叉树以某种次序遍历使其变化线索二叉树的过程称作线索化。

typedef struct TBTNode{	char data;	int ltag,rtag;//ltag=0,则lchild指向左孩子  ltag=1,则lchild指向直接前驱 同理rtag 	struct TBTNode *lchild;	struct TBTNode *rchild;}TBTNode;//中序线索化二叉树void InThread(TBTNode *p,TBTNode *&pre){	if(p!=NULL)	{		InThread(p->lchild,pre);		if(p->lchild==NULL)		{			p->lchild=pre;			p->ltag=1;		}		if(pre!=NULL&&pre->lchild==NULL)		{			pre->rchild=p;			pre->rtag=1;		}        pre=p;	    InThread(p->rchild,pre);	}} //求中序序列下的第一个结点TBTNode *First(TBTNode *p){	while(p->ltag==0)		p=p->lchild;	return p;} //求中序序列下的后继结点TBTNode *Next(TBTNode *p){	if(p->rtag==0)		return First(p->rchild);	else		return p->rchild;}

前序线索化

typedef struct TBTNode{	char data;	int ltag,rtag;//ltag=0,则lchild指向左孩子  ltag=1,则lchild指向直接前驱 同理rtag 	struct TBTNode *lchild;	struct TBTNode *rchild;}TBTNode;//前序线索化二叉树void preThread(TBTNode *p,TBTNode *&pre){	if(p!=NULL)	{ 		if(p->lchild==NULL)		{			p->lchild=pre;			p->ltag=1;		}		if(pre!=NULL&&pre->lchild==NULL)		{			pre->rchild=p;			pre->rtag=1;		}		pre=p;		if(p->ltag==0)			preThread(p->lchild,pre);		if(p->rtag==0)			preThread(p->rchild,pre);	}}

后序线索化

typedef struct TBTNode{	char data;	int ltag,rtag;//ltag=0,则lchild指向左孩子  ltag=1,则lchild指向直接前驱 同理rtag 	struct TBTNode *lchild;	struct TBTNode *rchild;}TBTNode;//后序线索化二叉树void PostThread(TBTNode *p,TBTNode *&pre){	if(p!=NULL)	{ 		PostThread(p->lchild,pre);		PostThread(p->rchild,pre);		if(p->lchild==NULL)		{			p->lchild=pre;			p->ltag=1;		}		if(pre!=NULL&&pre->lchild==NULL)		{			pre->rchild=p;			pre->rtag=1;		}	}}

 

转载地址:https://codingchaozhang.blog.csdn.net/article/details/85259596 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:二叉树的应用之根据序列确定二叉树
下一篇:二叉树应用之遍历算法的改进

发表评论

最新留言

初次前来,多多关照!
[***.217.46.12]2024年04月21日 17时16分36秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章

Linux内核在中国大发展的黄金十年-写于中国Linux存储、内存管理和文件系统峰会十周年之际... 2021-07-02
物联网 20 年简史大揭秘! 2021-07-02
开源项目|RT-Thread 软件包应用作品:水墨屏桌面台历 2021-07-02
珠联璧合!基于i.MX RT和RT-Thread的物联网云接入方案 2021-07-02
基于RTT-MicroPython制作自带BGM的新型肺炎晴雨表 2019-04-29
Arm宣布推出Cortex-M55核心和Ethos-U55 microNPU,瞄准低功耗Edge AI 2019-04-29
开源项目|RT-Thread 软件包应用作品:小闹钟 2019-04-29
在 RT-Thread Studio 上使用 RT-Thread Nano 2019-04-29
开源项目|软件包应用作品:通用物联网系统平台 2019-04-29
【经验分享】RT-Thread UART设备驱动框架初体验(中断方式接收带\r\n的数据) 2019-04-29
单片机里面的CPU使用率是什么鬼? 2019-04-29
推荐一个优质Linux技术公众号-作者都是一线Linux代码贡献者们哦 2019-04-29
RT-Thread 编程风格指南 2019-04-29
95后高校电子教师,软硬兼修有趣有料! 2019-04-29
使用 STM32 通用 Bootloader ,让 OTA 更加 Easy 2019-04-29
Cache 的基本概念与工作原理 2019-04-29
装机量超亿台 RISC-V +IoT OS!中科蓝讯与RT-Thread战略合作,共推自主物联网生态发展 2019-04-29
Android程序员必备!面试一路绿灯Offer拿到手软,Android面试题及解析 2019-04-29
Android程序员的春天!12个View绘制流程高频面试题,分享PDF高清版 2019-04-29
深入交流安卓!新鲜出炉的Android面试真题集锦我给你们整理出来了!Android面试题及解析 2019-04-29