二叉树应用之线索化
发布日期: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秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
物联网 20 年简史大揭秘!
2021-07-02
开源项目|RT-Thread 软件包应用作品:水墨屏桌面台历
2021-07-02
珠联璧合!基于i.MX RT和RT-Thread的物联网云接入方案
2021-07-02
基于RTT-MicroPython制作自带BGM的新型肺炎晴雨表
2019-04-29
开源项目|RT-Thread 软件包应用作品:小闹钟
2019-04-29
在 RT-Thread Studio 上使用 RT-Thread Nano
2019-04-29
开源项目|软件包应用作品:通用物联网系统平台
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
Android程序员必备!面试一路绿灯Offer拿到手软,Android面试题及解析
2019-04-29
Android程序员的春天!12个View绘制流程高频面试题,分享PDF高清版
2019-04-29