Chinaunix首页 | 论坛 | 博客
  • 博客访问: 209437
  • 博文数量: 35
  • 博客积分: 2691
  • 博客等级: 少校
  • 技术积分: 527
  • 用 户 组: 普通用户
  • 注册时间: 2008-01-11 09:42
文章分类

全部博文(35)

文章存档

2012年(5)

2010年(6)

2009年(2)

2008年(22)

我的朋友

分类: C/C++

2008-06-30 15:20:18

/*
 * 2008/06/30 By Yao Jianming
 * */
#include
#include
struct node {
        bool left_thread;
        bool right_thread;
        node *left_child;
        node *right_child;
        char data;
}*root;
//插入右节点
void insert_right(node *parent, node *p)
{
        p->right_thread = p->left_thread = true;
        p->left_child = parent;
        p->right_child = parent->right_child;
        parent->right_thread = false;
        parent->right_child = p;
}
//插入左节点
void insert_left(node *parent, node *p)
{
        p->right_thread = p->left_thread = true;
        p->right_child = parent;
        p->left_child = parent->left_child;
        parent->left_thread = false;
        parent->left_child = p;
}
//找到当前节点的后节点
node* insucc(node *p)
{
        if(p->right_thread == true) {
                return p->right_child;
        }
        else {
                p = p->right_child;
                while(p->left_thread != true) {
                        p = p->left_child;
                }
                return p;
        }
}
//遍历线索二叉树
void order(node *head)
{
        while(head->right_child != head) {
                printf("%c\n", head->data);
                head = insucc(head);
        }
}
int main()
{
        root = (node*)malloc(sizeof(node));
        root->right_thread = false;
        root->right_child = root;
        root->left_thread = true;
        root->left_child = root;

        node *A = (node*)malloc(sizeof(node));
        A->data = 'A';
        insert_left(root, A);
        node *G = (node*)malloc(sizeof(node));
        G->data = 'G';
        insert_right(A, G);
        node *Add = (node*)malloc(sizeof(node));
        Add->data = '+';
        insert_left(A, Add);
        node *H = (node*)malloc(sizeof(node));
        H->data = 'H';
        insert_right(Add, H);
        node *Multi = (node*)malloc(sizeof(node));
        Multi->data = '*';
        insert_left(Add, Multi);
        node *I = (node*)malloc(sizeof(node));
        I->data = 'I';
        insert_right(Multi, I);
        node *Div = (node*)malloc(sizeof(node));
        Div->data = '/';
        insert_left(Multi, Div);
        node *J = (node*)malloc(sizeof(node));
        J->data = 'J';
        insert_right(Div, J);
        node *O = (node*)malloc(sizeof(node));
        O->data = 'O';
        insert_left(Div, O);
        order(O);
}
以上实现的线索树如下:
 
阅读(1659) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~