版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
二叉树遍历实验报告完全二叉树:若设二叉树的深度为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年发展研究院招聘公共绩效与信息化研究中心项目主管岗位备考题库及1套参考答案详解
- 2026年项目看板信息共享合同
- 2025年上海市科创教育研究院招聘备考题库完整参考答案详解
- 浅谈急性乳腺炎
- 浏阳市卫生健康局2025年公开招聘乡村医生备考题库完整答案详解
- 2025年北京协和医院肿瘤内科合同制科研助理招聘备考题库及答案详解一套
- 中国电子行业CEIC2025前沿聚焦:从智能终端到医疗家居鸿蒙生态全场景展出
- 2025年北京协和医院变态(过敏)反应科合同制科研助理招聘备考题库及答案详解参考
- 证券行业2025年三季报总结:资本市场持续活跃前三季度净利润同比62%
- 2025年交通运输部所属事业单位第三批统一公开招聘390人备考题库含答案详解
- 生产部质量管理提升计划
- 电脑培训:如何高效使用电脑
- 人教版八年级数学上册期末复习:必刷基础60题(14种必考题型)
- 细胞外基质影响生物电导率-洞察分析
- 陕西省宝鸡市2025届高三上学期高考模拟检测(一)英语试卷(含答案无听力原文及音频)
- 钢结构及玻璃雨棚施工方案
- 报案书(参考范文)
- 汽车行业销售经理聘用合同
- DB11 527-2008 变配电室安全管理规范
- 出纳劳务合同模板
- 创新创业创造:职场竞争力密钥智慧树知到期末考试答案章节答案2024年上海对外经贸大学
评论
0/150
提交评论