#include <stdio.h>
#include <stdlib.h>
//定义结构
typedef struct Node
{
char data;
struct Node*LChild;
struct Node*RChild;
}BiTNode,*BiTree;
/*创建二叉树*/
void CreateBiTree(BiTree *bt)
{
char ch = getchar();
if(ch == '.')
{
*bt = NULL;
}else
{
*bt = (BiTree)malloc(sizeof(BiTNode));
(*bt) -> data = ch;
CreateBiTree(& ((*bt) -> LChild));
CreateBiTree(& ((*bt) -> RChild));
}
}
/*先序遍历二叉树*/
void PreOrder(BiTree root)
{
if(root != NULL)
{
printf("%c ",root -> data);/*访问根结点*/
PreOrder(root -> LChild);/*遍历左子树*/
PreOrder(root -> RChild);/*遍历右子树*/
}
}
/*中序遍历二叉树*/
void InOrder(BiTree root)
{
if(root != NULL)
{
InOrder(root -> LChild);/*遍历左子树*/
printf("%c ",root -> data);/*访问根结点*/
InOrder(root -> RChild);/*遍历右子树*/
}
}
/*后序遍历二叉树*/
void PostOrder(BiTree root)
{
if(root != NULL)
{
PostOrder(root -> LChild);/*遍历左子树*/
PostOrder(root -> RChild);/*遍历右子树*/
printf("%c ",root -> data);/*访问根结点*/
}
}
/*二叉树的高度*/
int PostTreeDepth(BiTree bt) /* 后序遍历求二叉树bt高度的递归算法 */
{
int hl, hr, max;
if(bt!=NULL)
{
hl=PostTreeDepth(bt->LChild); /* 求左子树的深度 */
hr=PostTreeDepth(bt->RChild); /* 求右子树的深度 */
max=hl>hr?hl:hr; /* 得到左、右子树深度较大者*/
return(max+1); /* 返回树的深度 */
}
else return(0); /* 如果是空树,则返回0 */
}
/*打印二叉树*/
int main(){
printf("输入:");
BiTree tree;
CreateBiTree(&tree);
printf("\n先序:");
PreOrder(tree);
printf("\n中序:");
InOrder(tree);
printf("\n后序:");
PostOrder(tree);
printf("\n二叉树的深度:%d\n",PostTreeDepth(tree));
return 0;
}
#include <stdlib.h>
//定义结构
typedef struct Node
{
char data;
struct Node*LChild;
struct Node*RChild;
}BiTNode,*BiTree;
/*创建二叉树*/
void CreateBiTree(BiTree *bt)
{
char ch = getchar();
if(ch == '.')
{
*bt = NULL;
}else
{
*bt = (BiTree)malloc(sizeof(BiTNode));
(*bt) -> data = ch;
CreateBiTree(& ((*bt) -> LChild));
CreateBiTree(& ((*bt) -> RChild));
}
}
/*先序遍历二叉树*/
void PreOrder(BiTree root)
{
if(root != NULL)
{
printf("%c ",root -> data);/*访问根结点*/
PreOrder(root -> LChild);/*遍历左子树*/
PreOrder(root -> RChild);/*遍历右子树*/
}
}
/*中序遍历二叉树*/
void InOrder(BiTree root)
{
if(root != NULL)
{
InOrder(root -> LChild);/*遍历左子树*/
printf("%c ",root -> data);/*访问根结点*/
InOrder(root -> RChild);/*遍历右子树*/
}
}
/*后序遍历二叉树*/
void PostOrder(BiTree root)
{
if(root != NULL)
{
PostOrder(root -> LChild);/*遍历左子树*/
PostOrder(root -> RChild);/*遍历右子树*/
printf("%c ",root -> data);/*访问根结点*/
}
}
/*二叉树的高度*/
int PostTreeDepth(BiTree bt) /* 后序遍历求二叉树bt高度的递归算法 */
{
int hl, hr, max;
if(bt!=NULL)
{
hl=PostTreeDepth(bt->LChild); /* 求左子树的深度 */
hr=PostTreeDepth(bt->RChild); /* 求右子树的深度 */
max=hl>hr?hl:hr; /* 得到左、右子树深度较大者*/
return(max+1); /* 返回树的深度 */
}
else return(0); /* 如果是空树,则返回0 */
}
/*打印二叉树*/
int main(){
printf("输入:");
BiTree tree;
CreateBiTree(&tree);
printf("\n先序:");
PreOrder(tree);
printf("\n中序:");
InOrder(tree);
printf("\n后序:");
PostOrder(tree);
printf("\n二叉树的深度:%d\n",PostTreeDepth(tree));
return 0;
}