java 二叉树_Java自学-集合框架 二叉树

Java集合框架 二叉树

示例 1 : 二叉树概念

二叉树由各种节点组成

二叉树特点: 每个节点都可以有子节点,子节点

每一个节点都有一个

664ac74e5025bc6803248a39b7443508.png
package 

示例 2 : 二叉树排序-插入数据

假设通过二叉树对如下10个随机数进行排序

67,7,30,73,10,0,78,81,10,74

排序的第一个步骤是把数据插入到该二叉树中

插入基本逻辑是,小、相同的放左边,大的放右边

1. 67 放在根节点

2. 7 比 67小,放在67的左节点

3. 30 比67 小,找到67的左节点7,30比7大,就放在7的右节点

4. 73 比67大, 放在67的右节点

5. 10 比 67小,找到67的左节点7,10比7大,找到7的右节点30,10比30小,放在30的左节点。

...

...

9. 10比67小,找到67的左节点7,10比7大,找到7的右节点30,10比30小,找到30的左节点10,10和10一样大,放在左边

9843b3d8ff0b2ba8b54376efb90faa1d.png
package 

示例 3 : 二叉树排序-遍历

通过上一个步骤的插入行为,实际上,数据就已经排好序了。 接下来要做的是看,把这些已经排好序的数据,遍历成我们常用的List或者数组的形式

二叉树的遍历分左序,中序,右序

左序即: 中间的数遍历后放在左边

中序即: 中间的数遍历后放在中间

右序即: 中间的数遍历后放在右边

如图所见,我们希望遍历后的结果是从小到大的,所以应该采用中序遍历

043ef24f4e1ab064f5a53bae63ac436e.png
package 

练习: 英雄二叉树

根据上面的学习和理解,设计一个Hero二叉树,HeroNode. 可以向这个英雄二叉树插入不同的Hero对象,并且按照Hero的血量倒排序。

随机生成10个Hero对象,每个Hero对象都有不同的血量值,插入这个HeroNode后,把排序结果打印出来。

107f076de9528ecfc9b11975870dc6f1.png
package 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值