收藏 分享(赏)

树形结构的应用数据结构实验.doc

上传人:11xg27ws 文档编号:12408467 上传时间:2021-12-12 格式:DOC 页数:7 大小:54KB
下载 相关 举报
树形结构的应用数据结构实验.doc_第1页
第1页 / 共7页
树形结构的应用数据结构实验.doc_第2页
第2页 / 共7页
树形结构的应用数据结构实验.doc_第3页
第3页 / 共7页
树形结构的应用数据结构实验.doc_第4页
第4页 / 共7页
树形结构的应用数据结构实验.doc_第5页
第5页 / 共7页
点击查看更多>>
资源描述

1、树形结构应用 实验日志实验题目:建立二叉树实验目的:掌握二叉树的定义、性质及存储方式,各种遍历算法。实验要求: 采用二叉树链表作为存储结构,完成二叉树的建立,先序、中序和后序遍历的操作。 实验主要步骤:1. 编写源程序,建立二叉树。2. 连接编译运行该程序,并在过程中调试。3. 实现各种遍历的操作。由二叉树的定义可知,一棵树由根结点、左子树和右子树三部分组成。因此,只要依次遍历这三部分,就可以遍历整个二叉树。若以 D、L 、R 分别表示访问根结点、遍历根结点的左子树、遍历根结点的右子树,则二叉树的遍历方式有六种:DLR、LDR、LRD、DRL、RDL 和 RLD。如果限定先左后右,则只有前三种

2、方式,即 DLR(称为先序遍历) 、LDR(称为中序遍历)和 LRD(称为后序遍历) 。 先序遍历算法:(1)访问根结点; (2)先序遍历左子树; (3)先序遍历右子树。 中序遍历算法:(1)中序遍历左子树; (2)访问根结点; (3)中序遍历右子树。 后序遍历算法:(1)后序遍历左子树; (2)后序遍历右子树; (3)访问根结点。源程序:#include#include#define TREE_TYPE inttypedef struct TREE_NODETREE_TYPE value;struct TREE_NODE *left; /左结点指针struct TREE_NODE *righ

3、t; /右结点指针TreeNode;/连接 temp 和 tree 两个节点 TreeNode* link(TreeNode *temp,TreeNode *tree,int key)tree = (TreeNode*)malloc(sizeof(TreeNode);if(temp != NULL)if(temp-value key)temp-left = tree;elsetemp-right = tree;tree-value = key;tree-left = NULL;tree-right = NULL;return tree;/插入并建立二叉树 TreeNode * insert(T

4、reeNode *tree,int key)TreeNode *temp = NULL,*p = tree; if(tree != NULL) while(tree != NULL tree = tree-left;elsetemp=tree;tree = tree-right;tree = link(temp,tree,key); else/if(tree = NULL)tree = link(temp,tree,key);/将下面注释掉的代码单独写成了一个函数 /*tree = (TreeNode*)malloc(sizeof(TreeNode);tree-value = key;tree

5、-left = NULL;tree-right = NULL;*/if(p != NULL)tree = p;return tree;/先序遍历 void print1(TreeNode *tree)if(tree)printf(“%3d,“,tree-value);print1(tree-left);print1(tree-right); /中序遍历 void print2(TreeNode *tree)if(tree)print2(tree-left);printf(“%3d,“,tree-value);print2(tree-right);/后序遍历 void print3(TreeNo

6、de *tree)if(tree != NULL)print3(tree-left);print3(tree-right);printf(“%3d,“,tree-value);int main()int key,i;TreeNode *tree;tree = NULL;printf(“请输入整型数:(以任意字符结束)n“); while(1)i = scanf(“%d“,if(i != 1)break;tree = insert(tree,key); printf(“n 先序遍历:“);print1(tree);printf(“n 中序遍历:“);print2(tree);printf(“n 后序遍历:“);print3(tree);printf(“n“);system(“pause“);return 0; 实验结果:心得体会:这次实验已经比上一次要熟练一些,并且对于这类算法的大致写法也有了一个了解,那就是递归算法的大量使用。在查错的时候对 C 语言以前忘记或不熟练的地方也进行了复习,同时,对二叉树的遍历也有了更深的理解。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 企业管理 > 管理学资料

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报