解题思路:
第一次写线索二叉树,根据一般二叉树的知识,和题目提示代码,以及课本代码凑出来了这个程序,

接下来就讲一讲什么如何修改课本代码,需要添加什么,才能使程序运行


①:

void InOrderThreading(Bithrtree *Thrt,Bithrtree T);/*中序遍历二叉树,并将其线索化*/
/*这个函数中pre需要自己定义*/
/*其中的Link,与Thread相当于全局变量分别等于0,1*/
/*Thrt为指向头结点指针的指针*/
/*T是首结点*/

void InThreading(Bithrtree T,Bithrtree *pre);
/*这个函数得要自己编写,在课本135页,需要注意的是,pre指针在这个函数里面也要用,所以与书上相比
要多加一个Bithrtree *pre,(书上的pre应该是全局变量)其作用是记录前驱,然后在 InOrderThreading这个函数中使用*/


注意事项:
不可以照着题目以及课本抄下来,课本上为了方便不全;

参考代码:

#include <stdio.h>
#include <malloc.h>

#define Link    0
#define Thread    1
#define MAX    101

typedef struct BithrNode_ {
    char            data;
    struct BithrNode_    *Lchild, *Rchild;
    int            LTag, RTag;
}*Bithrtree, BithrNode;


void CreatBitree( Bithrtree *T );                       /*创建二叉树*/

void InOrderThreading( Bithrtree *Thrt, Bithrtree T );  /*中序遍历二叉树,并将其线索化*/

void InThreading( Bithrtree T, Bithrtree *pre );

void InorderTraverse_Thr( Bithrtree T );                /*中序遍历算法*/


/*-----------------------------------------------------------------*/
int main()
{
    Bithrtree T, Thrt;

    CreatBitree( &T );

    InOrderThreading( &Thrt, T );

    InorderTraverse_Thr( Thrt );

    return(0);
}


/*-----------------------操作定义------------------------------------*/
void CreatBitree( Bithrtree *T ) /*创建二叉树*/
{
    char ch;
    scanf( "%c", &ch );
    if ( ch == ' ' )
        (*T) = NULL;
    else{
        (*T)        = (Bithrtree) malloc( sizeof(BithrNode) );
        (*T)->data    = ch;

        CreatBitree( &(*T)->Lchild );
        CreatBitree( &(*T)->Rchild );
    }
    return;
}


/*------------------------------------------------------------*/
void InOrderThreading( Bithrtree *Thrt, Bithrtree T )   /*中序遍历二叉树,并将其线索化*/
{
    Bithrtree pre = NULL;                           /*定义前驱指针*/
    (*Thrt) = (Bithrtree) malloc( sizeof(BithrNode) );


    (*Thrt)->LTag    = Link;                         /*建立头结点*/
    (*Thrt)->RTag    = Thread;
    (*Thrt)->Rchild = (*Thrt);                      /*右指针回指*/

    if ( !T )                                       /*若二叉树空,左指针回指*/
        (*Thrt)->Lchild = (*Thrt);
    else{
        (*Thrt)->Lchild = T;
        pre        = (*Thrt);
        InThreading( T, &pre );                 /*中序遍历,进行中序线索化*/
        pre->Rchild    = *Thrt;
        pre->RTag    = Thread;               /*最后一个结点线索化*/
        (*Thrt)->Rchild = pre;
    }
}


/*------------------------------------------------------------*/
void InThreading( Bithrtree T, Bithrtree *pre )
{
    if ( T )
    {
        InThreading( T->Lchild, pre );  /*左子树线索化*/
        if ( !T->Lchild )
        {
            T->LTag = Thread; T->Lchild = (*pre);
        }                               /* 前驱线索 */

        if ( !(*pre)->Rchild )
        {
            (*pre)->RTag = Thread; (*pre)->Rchild = T;
        }

        (*pre) = T;

        InThreading( T->Rchild, pre );  /*右子树线索化*/
    }
}


/*------------------------------------------------------------*/
void InorderTraverse_Thr( Bithrtree T )         /*中序遍历算法*/
{
    Bithrtree p = T->Lchild;
    while ( p != T )
    {
        while ( p->LTag == Link )
            p = p->Lchild;
        printf( "%c ", p->data );

        while ( p->RTag == Thread && p->Rchild != T )
        {
            p = p->Rchild;
            printf( "%c ", p->data );
        }
        p = p->Rchild;
    }
    return;
}

别忘点赞哦-.-


点赞(10)
 

0.0分

6 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论