




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
二叉树遍历实验报告完全二叉树:若设二叉树的深度为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至2030年中国气密检漏设备行业投资前景及策略咨询报告
- 2025至2030年中国气动执行器对夹蝶阀行业投资前景及策略咨询研究报告
- 2025至2030年中国毛线餐椅座垫市场分析及竞争策略研究报告
- 2025至2030年中国欧式花洒行业发展研究报告
- 2025至2030年中国橙汁藕粉行业发展研究报告
- 2025年山东省济南市市中区中考物理一模试卷(无答案)
- 2025年全国中小学生安全教育日专题
- 2025太阳能光热发电站熔融盐储热系统技术
- DL∕T 1751-2017 燃气-蒸汽联合循环机组余热锅炉运行规程
- 医院物业运送服务专项方案
- 氯化铵安全技术说明书MSDS
- 河海大学材料力学第五章弯曲应力
- 关于建立涉农贷款专项统计制的通知银发号
- 螺杆设计说明书
- 国家开放大学《理工英语3》章节测试参考答案
- 常用螺电批扭力选用对照表
评论
0/150
提交评论