版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
二叉树遍历实验报告完全二叉树:若设二叉树的深度为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版)
- 《深圳市工程建设标准化实施方案》深建字〔211〕97号附件
- 2025年电气工程施工员技能资格考试试题及答案解析
- 2026年互联网金融合作合同
- 2026年医用防护用品应急储备合同
- 钢结构玻璃雨棚制作安装合同协议书
- 安全生产宣传教育培训的工作汇报
- 2026年化学实验操作技能认定题库
- 2026年电子类专业工程类人员职级评定预测模拟题
- 数字孪生方案
- 【低空经济】无人机AI巡检系统设计方案
- 金融领域人工智能算法应用伦理与安全评规范
- 机动车驾校安全培训课件
- 2025年公务员多省联考《申论》题(陕西A卷)及参考答案
- 升降车安全技术交底(一)
- 附:江西省会计师事务所服务收费标准【模板】
- 合欢花苷类对泌尿系感染的抗菌作用
- 合伙人股权合同协议书
- 工程施工监理技术标
- 年终尾牙会领导讲话稿
评论
0/150
提交评论