快速业务通道

屈我峯糞?坿旗鷹

作者 佚名技术 来源 程序设计 浏览 发布时间 2012-06-30

屈我峯糞?坿旗鷹泌和?

#include <conio.h>
#include <stdio.h>
#include <stdlib.h>
#define OK 1
#define ERROR 0
#define TRUE 1
#define FALSE 0
#define OVERFLOW -2
typedef int status;
typedef struct BiNode
{
  char Data;
  struct BiNode* lChild;
  struct BiNode* rChild;
}BiNode,*pBiNode;
status CreateTree(BiNode** pTree);
status PreOrderTraval(BiNode* pTree);
status Visit(char Data);
status Display(BiNode* pTree,int Level);
status Clear(BiNode* pTree);
BiNode *pRoot=NULL;
main()
{
  clrscr();
  CreateTree(&pRoot);
  printf("\nPreOrder:");
  PreOrderTraval(pRoot);
  printf("\n");
  printf("\nInOrder:");
  InOrderTraval(pRoot);
  printf("\n");
  printf("\nPostOrder:");
  PostOrderTraval(pRoot);
  printf("\n");
  printf("\nShowLeaves:");
  ShowLeaves(pRoot);
  printf("\n-----------------------\n");
  printf("\n");
  Display(pRoot,0);
  printf("\n");
  printf("\nDeleting Tree:\n");
  DelTree(pRoot);
  printf("BiTree Deleted.");
  getch();
}
status CreateTree(BiNode** pTree) /*Input Example: abd##e##cf##g##*/
{
  char ch;
  scanf("%c",&ch);
  if(ch==‘#‘)
  {
    (*pTree)=NULL;
  }
  else
  {
    if(!((*pTree)=(BiNode*)malloc(sizeof(BiNode))))
    {
      exit(OVERFLOW);
    }
    (*pTree)->Data=ch;
    CreateTree(&((*pTree)->lChild));
    CreateTree(&((*pTree)->rChild));
  }
return OK;
}
status PreOrderTraval(BiNode* pTree)
{
  if(pTree)
  {
    if(Visit(pTree->Data))
    {
      if(PreOrderTraval(pTree->lChild))
      {
        if(PreOrderTraval(pTree->rChild))
        {
          return OK;
        }
      }
    }
    return ERROR;
  }
  else
  {
    return OK;
  }
}
status InOrderTraval(BiNode* pTree)
{
  if(pTree)
  {
    if(InOrderTraval(pTree->lChild))
    {
      if(Visit(pTree->Data))
      {
        if(InOrderTraval(pTree->rChild))
        {
          return OK;
        }
      }
      return ERROR;
    }
    return ERROR;
  }
  else
  {
    return OK;
  }
}
status PostOrderTraval(BiNode* pTree)
{
  if(pTree)
  {
    if(PostOrderTraval(pTree->lChild))
    {
      if(PostOrderTraval(pTree->rChild))
      {
        if(Visit(pTree->Data))
        {
          return OK;
        }
        return ERROR;
      }
    }
    return ERROR;
  }
  else
  {
    return OK;
  }
}
status Visit(char Data)
{
  printf("%c",Data);
  return OK;
}
status Display(BiNode* pTree,int Level)
{
  int i;
  if(pTree==NULL) return;
  Display(pTree->lChild,Level+1);
  for(i=0;i<Level-1;i++)
  {
    printf(" ");
  }
  if(Level>=1)
  {
    printf("--");
  }
  printf("%c\n",pTree->

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号