c语言二叉树括号表示法,二叉树的遍历操作实现二. 实验内容与要求1.建立二叉树二叉链存贮结构。2. 根据二叉树的括号表示方法,建立一棵二叉树。3...

共回答了31个问题采纳率:90.3%

// S_lbecs.cpp : 定义控制台应用程序的入口点。

//链表二叉树的定义和操作

#include "stdafx.h"

#include "stdio.h"

#include "malloc.h"

#include "string.h"

#include "stdlib.h"

#define Max 20 //最大节点个数

typedef struct node{

char data;

struct node *lchild,*rchild; //左边孩子的指针 和 右边孩子的指针

}BinTNode;

typedef BinTNode *BinTree; //定义二叉树的指针

int NodeNum,leaf; //NodeNum是结点数 leaf是叶子数

//基于先序遍历算法创建二叉树

//要求输入先序序列,其中加入虚结点“#”以示空指针的位置

BinTree CreatBinTree(void){

BinTree T;

char ch;

scanf("%c",&ch);

if(ch=='#') //读入# 返回空指针

return(NULL);

else{

T=(BinTNode *)malloc(sizeof(BinTNode)); //生成结点

T->data=ch;

T->lchild=CreatBinTree(); //构造左子树

T->rchild=CreatBinTree(); //构造右子树

return(T);

}

}

//DLR 先序遍历

//访问根节点 先序遍历左子树 先序遍历右子树

void Preorde(BinTree T){

if(T){

printf("%c",T->data); //访问结点 D

Preorde(T->lchild); //先序遍历左子树 L

Preorde(T->rchild); //先序遍历右子树 R

}

}

//LDR 中序遍历

void Inorder(BinTree T){

if(T){

Inorder(T->lchild); //中序遍历左子树 L

printf("%c",T->data); //访问结点 D

Inorder(T->rchild); //中序遍历右子树 R

}

}

//LRD 后序遍历

void Postorder(BinTree T){

if(T){

Postorder(T->lchild); //后序遍历左子树 L

Postorder(T->rchild); //后序遍历右子树 R

printf("%c",T->data); //访问结点 D

}

}

//采用后序遍历求二叉树的深度、结点数及叶子数的递归算法

int TreeDepth(BinTree T){

int hl,hr,max;

if(T){

hl=TreeDepth(T->lchild); //求左深度

hr=TreeDepth(T->rchild); //求右深度

max=hl>hr?hl:hr; //取最大深度

NodeNum=NodeNum+1; //求结点数

if(hl==0&&hr==0) //若左右深度都为0 则为叶子

leaf=leaf+1;

return(max+1);

}else{

return(0);

}

}

//利用“先进先出”(FIFO)队列,按层次遍历二叉树

void Levelorder(BinTree T){

int front=0,rear=1;

BinTNode *cq[Max],*p; //定义结点的指针数组cq

cq[1]=T; //根入队

while(front!=rear){

front=(front+1)%NodeNum;

p=cq[front]; //出队

printf("%c",p->data); //输出结点的值

if(p->lchild!=NULL){

rear=(rear+1)%NodeNum;

cq[rear]=p->lchild; //左子树入队

}

if(p->rchild!=NULL){

rear=(rear+1)%NodeNum;

cq[rear]=p->rchild; //右子树入队

}

}

}

int _tmain(int argc, _TCHAR* argv[])

{

BinTree root;

int i,depth; //最大深度

printf("n创建二叉树;输入完全二叉树先序序列:");

//用#代表虚结点 如ABD###CE##F##

root=CreatBinTree(); //创建二叉树 返回根结点

printf("n创建成功!n");

do{ //从菜单中选择遍历方式,输入序号。

printf("t********** select ************n");

printf("t1: 先序遍历n");

printf("t2: 中序遍历n");

printf("t3: 后序遍历n");

printf("t4: 求树的深度及叶子数n");

printf("t5: 按层次遍历n"); //按层次遍历之前,先选择4,求出该树的结点数。

printf("t0: 退出n");

printf("t*******************************n请选择:");

scanf("%d",&i); //输入菜单选项 0-5

switch(i){

case 1:

//1: 先序遍历 Preorde

printf("先序遍历的结果是");

Preorde(root); //

printf("n");

break;

case 2:

//2: 中序遍历 Inorder

printf("中序遍历的结果是");

Inorder(root); //

printf("n");

break;

case 3:

//3: 后序遍历 Postorder

printf("后序遍历的结果是");

Postorder(root); //

printf("n");

break;

case 4:

//4: 求树的深度及叶子数 TreeDepth

depth=TreeDepth(root); //

printf("数的深度=%d 结点数=%d",depth,NodeNum);

printf(" 叶子数=%d",leaf);

printf("n");

break;

case 5:

//5: 按层次遍历 Preorde

printf("按层次遍历的结果是");

Levelorder(root); //

printf("n");

break;

default:

printf("输入错误n");

break;

}

}while(i!=0);

return 0;

}

是vs做的 有些地方需要改下 是C语言做的

1年前

1

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值