版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
二叉树遍历实验报告完全二叉树:若设二叉树的深度为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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年度原材料采购:木屑长期供应合同
- 2024年度代持能源权益合同
- 2024年度工程承包合同:基础设施建设施工合同
- 04版电子商务平台搭建与运营合同
- 2024年度物联网技术应用合同
- 湿式潜水衣市场发展现状调查及供需格局分析预测报告
- 贵金属制钥匙圈市场需求与消费特点分析
- 灯罩座市场发展现状调查及供需格局分析预测报告
- 2024年度智慧城市系统开发与应用合同
- 磁带录音机市场发展现状调查及供需格局分析预测报告
- 防渗墙验收、记录表
- 市心血管重点专科汇报材料
- 工程量确认单[]
- 出境领队服务程序与规范(共36页).ppt
- 数控线切割中级工试题
- 华为物料品质试验中心KPI指标体系
- 机械零件轴测图精品
- 国培计划操作手册
- 英语《花木兰》短剧剧本
- 入侵报警系统工程施工要求及调试
- 基于PLC的燃油锅炉控制系统设计毕设设计说明书论文
评论
0/150
提交评论