首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

二叉树的左右子树的对换有关问题?

2012-03-12 
二叉树的左右子树的对换问题???#includestdio.h#include malloc.h#include conio.htypedef int Data

二叉树的左右子树的对换问题???
#include<stdio.h>
#include <malloc.h>
#include <conio.h>
typedef int DataType; 
typedef struct Node
{
 DataType data;
 struct Node *LChild;
 struct Node *RChild;
}BitNode,*BitTree;
void CreatBiTree(BitTree *bt)//用扩展先序遍历序列创建二叉树,如果是#当前树根置为空,否则申请一个新节点//
{
 char ch;
 ch=getchar();
 if(ch=='#')*bt=NULL;
 else
 {
  *bt=(BitTree)malloc(sizeof(BitNode));
  (*bt)->data=ch;
  CreatBiTree(&((*bt)->LChild));
  CreatBiTree(&((*bt)->RChild));
 }
}
void Visit(char ch)//访问根节点
{
 printf("%c ",ch);
}
void PreOrder(BitTree root) /*先序遍历二叉树, root为指向二叉树(或某一子树)根结点的指针*/
{
 if (root!=NULL)
 {
  Visit(root ->data); /*访问根结点*/
  PreOrder(root ->LChild); /*先序遍历左子树*/
  PreOrder(root ->RChild); /*先序遍历右子树*/
 }
}
void InOrder(BitTree root)  
/*中序遍历二叉树, root为指向二叉树(或某一子树)根结点的指针*/
{
 if (root!=NULL)
 {
  InOrder(root ->LChild); /*中序遍历左子树*/
  Visit(root ->data); /*访问根结点*/
  InOrder(root ->RChild); /*中序遍历右子树*/
 }
}

void PostOrder(BitTree root)  
/* 后序遍历二叉树,root为指向二叉树(或某一子树)根结点的指针*/
{
 if(root!=NULL)
 {
  PostOrder(root ->LChild); /*后序遍历左子树*/
  PostOrder(root ->RChild); /*后序遍历右子树*/
  Visit(root ->data); /*访问根结点*/
 }
}
int PostTreeDepth(BitTree 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 Sumleaf(BitTree T){ //二叉树的叶子结点递归算法
  int sum=0,m,n; 
  if(T){ 
  if((!T->LChild)&&(!T->RChild)) 
  sum++; 
  m=Sumleaf(T->LChild); 
  sum+=m; 
  n=Sumleaf(T->RChild); 
  sum+=n;

  return sum; } 
void main()
{
 BitTree T;
 int h,w;
 int layer;
 int treeleaf;
 layer=0;
 printf("请输入二叉树中的元素(以扩展先序遍历序列输入,其中#代表空子树):\n");
  CreatBiTree(&T);
 printf("先序遍历序列为:");
 PreOrder(T);
 printf("\n中序遍历序列为:");
 InOrder(T);
 printf("\n后序遍历序列为:");
 PostOrder(T);
 h=PostTreeDepth(T);
  printf("\n深度为:%d\n",h);
w=Sumleaf(T);
printf("\n叶子节点的数目:%d",w);
}
//为什么对换后的变成了只输出左子树或者右子树,而且输出的也有错误。

[解决办法]
什么错误?
[解决办法]
递归更好一些

热点排行