码迷,mamicode.com
首页 > 其他好文 > 详细

二叉树的建立与先序,后序,中序输出

时间:2017-05-13 22:10:27      阅读:331      评论:0      收藏:0      [点我收藏+]

标签:基本   can   否则   最大的   white   while   family   bre   int   

如果二叉树为:

                              a

             b                                 c

                     d                                 e

由于程序中要知道叶子结点(终点)。所以要讲上面的二叉树变成扩展二叉树(把叶子结点的孩子补成#,用作标记),扩展后就变成了:

                                    a

                    b                                 c

          #                  d              #                e

                       #             #                   #          #

那么在输入的时候,须要输入ab#d##c#e##(输入后直接回车就可以)

#include <stdio.h>
#include<stdlib.h>
#define ElemType char
//节点声明,数据域、左孩子指针、右孩子指针
typedef struct BiTNode{
char data;
struct BiTNode *lchild, *rchild;
}BiTNode, *BiTree;
BiTree createBiTree()

BiTree T;
char ch;
scanf("%c", &ch);
if (ch == ‘#‘)
T = NULL;
else
{
T = (BiTree)malloc(sizeof(BiTNode));
T->data = ch;
T->lchild = createBiTree();
T->rchild = createBiTree();
}
return T;

}

以下就是二叉树的遍历。遍历是通过递归进行遍历

//先序遍历
void PreorderTraverse(BiTree T)
{
if (T)
{
printf("%c\n", T->data);
PreorderTraverse(T->lchild);

PreorderTraverse(T->rchild);
}
}
//中序遍历
void InorderTraverse(BiTree T)
{
if (T)
{

PreorderTraverse(T->lchild);
printf("%c\n", T->data);
PreorderTraverse(T->rchild);
}
}
//后序遍历
void PostorderTraverse(BiTree T)
{
if (T)
{
PreorderTraverse(T->lchild);
PreorderTraverse(T->rchild);
printf("%c\n", T->data);
}

}

二叉树高度的求法返回T所指向的二叉树的高度

处理方法:1.若T为空则返回0否则

                2.求出左右子树的高度L1和L2。并返回两者之中最大的。

                3.由于没有算根节点仅仅是求的左右子树。所以须要加1。

int dep(BiTree T)
{
int max;
if (T == NULL)
return 0;
else
{
max = dep(T->lchild);
if (dep(T->rchild) > max)
max = dep(T->rchild);

}
return max + 1;
}

int main(void)
{
int ch;
BiTree T;
printf("请利用先序插入法插入您要建立的二叉树!\n");
T = createBiTree();
while (1)
{
printf("按下列选项选择您要进行的操作\n");
printf("1前序输出.\n");
printf("2.后序输出\n");
printf("3.中序输出\n");
printf("4.退出\n");
scanf("%d", &ch);
switch (ch)
{
case 1:
PreorderTraverse(T); break;
case 2:
PostorderTraverse(T); break;
case 3:
InorderTraverse(T); break;
case 4:
return 0;
default:
break;
}


}
return 0;
    

}


技术分享



以下是我做的一点点改进,利用c++中的指针引用将问题进行了简单的改动。以下是基本的两个函数。就是BST树的构建函数以及主函数

构建函数

技术分享

这样的方法不须要返回值了,是直接对指针进行操作。

技术分享

主函数的写法

技术分享

技术分享

二叉树的建立与先序,后序,中序输出

标签:基本   can   否则   最大的   white   while   family   bre   int   

原文地址:http://www.cnblogs.com/liguangsunls/p/6850431.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!