1680: 树-二叉树链式结构实现(不推荐学生做)
金币值:2
定数:11
时间限制:1.000 s
内存限制:128 M
正确:1
提交:5
正确率:20.00% 命题人:
题目描述
#include <string.h> #include <stdio.h> #include <stdlib.h> #define OK 1 #define ERROR 0 #define TRUE 1 #define FALSE 0 typedef int Status; /* Status是函数的类型,其值是函数结果状态代码,如OK等 */ /* 用于构造二叉树********************************** */ int pos=0; typedef char String[24]; String str; //全局变量 /* ************************************************ */ typedef char TElemType; TElemType Nil=' '; /* 字符型以空格符为空 */ Status visit(TElemType e) { printf("%c ",e); return OK; } typedef struct BiTNode { /* 结点结构 */ TElemType data; /* 结点数据 */ struct BiTNode *lchild,*rchild; /* 左右孩子指针 */ } BiTNode,*BiTree; /* 构造空二叉树T */ Status InitBiTree(BiTree &T) { } /* 初始条件: 二叉树T存在。操作结果: 销毁二叉树T */ void DestroyBiTree(BiTree &T) { } /* 按前序输入二叉树中结点的值(一个字符) */ /* #表示空树,构造二叉链表表示二叉树T。 */ void CreateBiTree(BiTree &T) { TElemType ch; } /* 初始条件: 二叉树T存在 */ /* 操作结果: 若T为空二叉树,则返回TRUE,否则FALSE */ Status BiTreeEmpty(BiTree T) { } /* 初始条件: 二叉树T存在。操作结果: 返回T的深度 */ int BiTreeDepth(BiTree T) { } /* 操作结果: 若二叉树T非空,则返回T的根,否则返回NULL */ TElemType Root(BiTree T) { } /* 初始条件: 二叉树T存在,p指向T中某个结点 */ /* 操作结果: 返回p所指结点的值 */ TElemType Value(BiTree p) { } /* 给p所指结点赋值为value */ void Assign(BiTree p,TElemType value) { } /* 初始条件: 二叉树T存在 */ /* 操作结果: 前序递归遍历T */ void PreOrderTraverse(BiTree T) { } /* 初始条件: 二叉树T存在 */ /* 操作结果: 中序递归遍历T */ void InOrderTraverse(BiTree T) { } /* 初始条件: 二叉树T存在 */ /* 操作结果: 后序递归遍历T */ void PostOrderTraverse(BiTree T) { } int main(void) { int i; BiTree T; TElemType e1; InitBiTree(T); gets(str); CreateBiTree(T); printf("构造二叉树后,树空否?%d(1:是 0:否) 树的深度=%d\n",BiTreeEmpty(T),BiTreeDepth(T)); e1=Root(T); printf("二叉树的根为:%c\n",e1); printf("前序遍历二叉树:"); PreOrderTraverse(T); printf("\n中序遍历二叉树:"); InOrderTraverse(T); printf("\n后序遍历二叉树:"); PostOrderTraverse(T); DestroyBiTree(T); printf("\n清除二叉树后,树空否?%d(1:是 0:否) 树的深度=%d\n",BiTreeEmpty(T),BiTreeDepth(T)); i=Root(T); if(!i) printf("树空,无根\n"); return 0; }
输入格式
输入一行:字符串(见样例)
输出格式
见样例
输入样例 复制
ABDH#K###E##CFI###G#J##
输出样例 复制
构造二叉树后,树空否?0(1:是 0:否) 树的深度=5
二叉树的根为:A
前序遍历二叉树:A B D H K E C F I G J
中序遍历二叉树:H K D B E A I F C G J
后序遍历二叉树:K H D E B I F J G C A
清除二叉树后,树空否?1(1:是 0:否) 树的深度=0
树空,无根
提示
提示:String str; 定义了str是一个全局字符串变量,里面可以存储了若干个字符(主函数从键盘中输入相关的字符)。
创建二叉树时需要从该变量中依次提取字符,实现的方法是: (1) 设置一个静态局部变量pos,初始值为0,提取出当前字符之后,再让pos++,以便下次递归调用时提取下一个字符;
或(2) 设置一个全局变量pos,初始值为0,提取出当前字符之后,再让pos++,以便下次递归调用时提取下一个字符(本题提供的代码中定义了一个全局变量pos)。