只为小站
首页
域名查询
文件下载
登录
首页
数据结构树的操作实验报告
数据结构树的操作实验报告
上传者:
yuwenjuan1
|
上传时间: 2022-12-14 19:34:01
|
文件大小: 111KB
|
文件类型: RAR
数据结构树的操作实验报告
一、实验目的: 理解二叉树特别是完全二叉树的性质,掌握二叉树的存储结构(二叉链表);熟练掌握二叉树的常用操作算法(初始化、插入结点、删除结点、遍历等);初步掌握二叉树的应用。 二、实验内容: 要求采用二叉链表作为存储结构,完成二叉树的建立,前序、中序和后序遍历的操作,求所有叶子及结点总数的操作等。 具体要求如下: ①给出基于二叉链表的二叉树类的定义; ②给出二叉树初始化(构造函数)的实现; ③给出二叉树三种遍历算法的递归实现; ④二叉树先序遍历的非递归算法实现; ⑤利用二叉树的遍历算法求二叉树的结点数、二叉树的叶结点数、二叉树的高度; ⑥二叉树的撤销删除 三、实验步骤: 1、需求分析: 本演示程序用JAVA编写,完成树的生成,任意位置的插入、删除,以及遍历二叉树中的结点,查找和修改树中元素的值。 ① 输入的形式和输入值的范围:插入元素时需要输入插入的位置和元素的值;删除元素时输入删除元素的位置;遍历时采用三种遍历方法中的一种遍历方法;修改操作时需要输入的元素的值;查找操作时,需要找到要查找元素的位置。在所有输入中,元素的值都是整数。 ② 输出的形式:在所有四种操作中都显示操作是否正确以及操作后树中的内容。其中删除操作后显示删除的元素的值,遍历二叉树中的元素,查找操作、修改操作后显示修改的值。 ③ 程序所能达到的功能:完成树的生成(通过插入操作)、插入、删除、遍历、查找、修改操作。 ④ 测试数据: A. 树中已有以50,25,75,12,37,43,30,33,87,93,97为关键字的结点 B. 插入操作中依次输入10,20,30,40,50,60,70,80,90,100十个数 C. 删除操作中输入10删除值为10的元素 D. 查找操作中输入20,30,40,50返回这个元素在树中的位置 2.概要设计: 1)为了实现上述程序功能,需要定义树的抽象数据类型: public int iData; public double dData; public Node leftChild; public Node rightChild; private Node root;int value; private Node getSuccessor; 基本操作:{ Tree () 操作结果:构造一个空的二叉树 insert () 初始条件:是否存在一个空二叉树 操作结果:往二叉树中插入数值 delete () 初始条件:存在一非空的二叉树 操作条件:将二叉树中的元素删除 displayTree () 初始条件:存在一非空的树 操作条件:显示非空树中的所有元素的值 getString () 初始条件:存在一非空的二叉树 操作结果:返回整个字符串的数值 getChar () 初始条件:存在一非空的二叉树 操作结果:返回字符型的数值 getInt () 初始条件:存在一非空的二叉树 操作结果:返回整型的数值 find () 初始条件:存在一非空二叉树 操作结果:从二叉树中查找某一元素 traverse () 初始条件:存在一非空的二叉树 操作结果:对二叉树中的元素进行遍历 preorder () 初始条件:存在一非空的二叉树 操作结果:对二叉树中的元素进行先根遍历 inOrder () 初始条件:存在一非空的二叉树 操作结果:对二叉树中的元素进行中根遍历 postOrder () 初始条件:存在一非空的二叉树 操作结果:对二叉树中的元素进行后根遍历 DisplayNode () 初始条件:存在一非空的二叉树 操作结果:显示出二叉树中的整形数值和双精度浮点型数值 public static void main 操作结果:调用主函数
文件下载
立即下载
资源详情
[{"title":"( 1 个子文件 111KB ) 数据结构树的操作实验报告","children":[{"title":"数据结构树的操作实验报告.doc <span style='color:#111;'> 172.00KB </span>","children":null,"spread":false}],"spread":true}]
评论信息
其他资源
Infor WMS CRB Studio开发手册
Qt游戏编程——飞机大战
Matlab实现DDS仿真
802.11官方协议下载
PHP校园订餐系统PHP校园订餐系统
Android实时曲线.rar
Matlab彩色图像边缘检测-canny_edgecolor.m
ISO13818(包含中文版和英文版)
旅游数据管理系统vbnet+sql
使用jsp+servlet+mysql+tomcat的java web,很简单,只是一个流程,供大家参考
mchange-commons-java-0.2.3.4.jar
PIX window连接驱动
CCP 驱动程序
Modelling and attitude control of a miniatureducted fan UAV
数字档案室建设指南.pdf
sh_area.sql
ch17-Distributed-File Systems.ppt
问卷调查网站
My97Date日历插件开发包
h3cne实验指导书电子版手册
c#操作XML,以及XML与TreeView控件的交互操作的例程
安卓航班Android开发经典教程大总结1----基础编程及源码推送
基于单片机的电阻对焊控制箱的设计与实现
Eclipse编译Hive
H+ 后台主题UI框架(可用完整)
欧姆龙例子控制4个电机,功能块,看完保证你就成高手
刚学的OpenGL画五角星
免责申明
【只为小站】的资源来自网友分享,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,【只为小站】 无法对用户传输的作品、信息、内容的权属或合法性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论 【只为小站】 经营者是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。
本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二条之规定,若资源存在侵权或相关问题请联系本站客服人员,zhiweidada#qq.com,请把#换成@,本站将给予最大的支持与配合,做到及时反馈和处理。关于更多版权及免责申明参见 版权及免责申明
个人信息
点我去登录
购买积分
下载历史
恢复订单
相关资源标签
热门下载
STM32F4时钟触发ADC双通道采样DMA传输进行FFT+测频率+采样频率可变+显示波形
java-spring-web-外文文献翻译40篇.zip
校园网规划与设计(报告和pkt文件)
基于VMD算法的信号降噪.rar
PSO-LSSVM的MATLAB代码.rar
通过svm cnn knn对高光谱数据集PaviaU进行分类(matlab)
多目标优化算法(四)NSGA3的代码(MATLAB)
空间谱估计理论与算法------程序.rar
基于MATLAB的Filter使用,低通、带通和高通滤波器的仿真
拾荒者扫描器.zip
Academic+Phrasebank+2021+Edition+_中英文对照.pdf
神经·模糊·预测控制及其MATLAB实现PDF + MATLAB程序
MATLAB车牌识别系统
计算机专业实习日记+实习周记+实习总结
Vivado永久激活license(亲测可用)包(搜集的全部可用LICENSE)
最新下载
vivado从此开始
ET2018版 CAD
C#屏幕广播源码V1.0
黄历数据库,mysql格式可直接使用
基于MATLAB平台的电机及拖动系统仿真.rar
华为USG6000V500R001C30SPC100.bin,V1升级V5过渡包
电路10the,James W.Nilsson / Susan A.Riedel
西游H5前后端完整源代码
3D、排3大底交并集软件
源码开放的嵌入式系统软件分析与实践.rar