




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
二叉树遍历实验报告完全二叉树:若设二叉树的深度为h,除第h层外,其它各层(1~h-1)的结点数都达到最大个数,第h层所有的结点都连续集中在最左边,这就是完全二叉树。完全二叉树从根结点到倒数第二层满足完美二叉树,最后一层可以不完全填充,其叶子结点都靠左对齐。特点:1)所有的叶节点都出现在最后一层或倒数第二层2)任一节点,其左子树的最大层数和右子树最大层数相同或比其大一层。3)最后一个叶节点为节点长度/2(第一个节点记作0,所以向下取整,记作i),叶节点的左子树根节点为2*i+1,若存在右子树,则右子树根节点为2*i+2。完全二叉树代码:创建节点类(Node)package
NO1;
//创建节点类
public
class
Node
{
private
String
value;
private
Node
leftNode;
private
Node
rightNode;
public
Node(String
value)
{
this.value=value;
}
public
Node()
{}
public
String
getValue()
{
return
value;
}
public
void
setValue(String
value)
{
this.value
=
value;
}
public
Node
getLeftNode()
{
return
leftNode;
}
public
void
setLeftNode(Node
leftNode)
{
this.leftNode
=
leftNode;
}
public
Node
getRightNode()
{
return
rightNode;
}
public
void
setRightNode(Node
rightNode)
{
this.rightNode
=
rightNode;
}
}创建二叉树类package
NO1;
import
java.util.List;
import
java.util.ArrayList;
//完全二叉树类
public
class
BinaryTree
{
private
Node
root;
//根节点
public
BinaryTree(String
value)
{
Node
node=new
Node(value);
root=node;
}
public
BinaryTree()
{}
public
Node
getRoot()
{
return
root;
}
public
void
setRoot(Node
root)
{
this.root
=
root;
}
}添加完全二叉树节点方法(addNodes)public
void
addNodes(String
a[])
{
List<Node>
list=new
ArrayList<>();
for(int
i=0;i<a.length;i++)
{
Node
node=new
Node(a[i]);
list.add(node);
}
root=list.get(0);
for(int
i=0;i<a.length/2;i++)
{
list.get(i).setLeftNode(list.get(2*i+1));
if(2*i+2<=a.length-1)
{
list.get(i).setRightNode(list.get(2*i+2));
}
}
}添加遍历方法public
void
preorder(Node
node,List<String>
list)
{
//前序排列
if(node!=null)
{
list.add(node.getValue());
preorder(node.getLeftNode(),
list);
preorder(node.getRightNode(),
list);
}
}
public
void
midorder(Node
node,List<String>
list)
{
//中序
if(node!=null)
{
midorder(node.getLeftNode(),
list);
list.add(node.getValue());
midorder(node.getRightNode()
,
list);
}
}
public
void
postorder(Node
node,List<String>
list)
{
//后序
if(node!=null)
{
postorder(node.getLeftNode(),
list);
postorder(node.getRightNode(),
list);
list.add(node.getValue());
}
}创建测试类(Test)package
NO1;
import
java.util.List;
import
java.util.ArrayList;
public
class
Test
{
public
static
void
main(String[]
args)
{
//
TODO
Auto-generated
method
stub
String
a[]=
{"A","B","C","D","E","F","G","H","I","J"};
BinaryTree
tree1=new
BinaryTree();
tree1.addNodes(a);
List<String>
list1=new
ArrayList<>();
List<String>
list2=new
ArrayList<>();
List<String>
list3=new
ArrayList<>();
tree1.preorder(tree1.getRoot(),
list1);
tree1.midorder(tree1.getRoot(),
list2);
tree1.postorder(tree1.getRoot(),
list3);
System.out.println("
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年上海市宝山区同济中学物理高一第二学期期末综合测试试题含解析
- 山西省忻州市岢岚中学2025届物理高二下期末联考模拟试题含解析
- 2025届云南省宣威市第十中学物理高一第二学期期末经典试题含解析
- 2025届福建省长汀、连城一中等六校高一物理第二学期期末考试试题含解析
- 2025届贵州省铜仁伟才实验学校物理高二第二学期期末达标测试试题含解析
- 2025届广西两校高二物理第二学期期末质量跟踪监视试题含解析
- 室内装潢工程承包协议
- 超市日常运营优化合作协议
- 健身房私人教练服务协议
- 电商平台虚拟试衣镜软件开发协议
- 呼伦贝尔农垦集团有限公司招聘笔试题库2025
- 城市道路无障碍设施课件
- 询价单(表格模板)
- 教师政审个人现实表现材料范文(通用5篇)
- QC降低矿山法围岩隧道爆破超挖量
- 2023年5月FDA口服速释制剂根据BCS分类系统的生物利用度与生物等效性研究及生物等效性豁免
- 校园文化建设方案(共60张PPT)
- 蓝色海洋经济海事航海渔业水产养殖港口码头海运PPT模板
- 不饱和聚酯树脂化学品安全技术说明书MSDS
- 机动车排放检验比对试验报告
- 一级二级三级医养结合机构服务质量评价标准(试行)
评论
0/150
提交评论