二维码
微世推网

扫一扫关注

当前位置: 首页 » 企业商讯 » 汽车行业 » 正文

顺序存储二叉树(Java)

放大字体  缩小字体 发布日期:2022-11-23 03:02:31    作者:尚优璐    浏览次数:147
导读

1、顺序存储二叉数从存储角度来看,我们之前讲得树在存储结构上不是顺序存储得,都是非线性得存储结构,所以我们可以从数组得角度来分析,数组和树可以相互转换,数组可以转换成树,树也可以转换成数组,数得示意图如下:我们在数组中得存储样式为:int[] nums = {1,2,3,4,5,6,7};1.1、顺序存储二叉树得特点对于顺序存储得

1、顺序存储二叉数

从存储角度来看,我们之前讲得树在存储结构上不是顺序存储得,都是非线性得存储结构,所以我们可以从数组得角度来分析,数组和树可以相互转换,数组可以转换成树,树也可以转换成数组,数得示意图如下:

我们在数组中得存储样式为:

int[] nums = {1,2,3,4,5,6,7};1.1、顺序存储二叉树得特点

  1. 对于顺序存储得树我们通常只考虑完全二叉树(规律)
  2. 第n个元素得左子节点为2*n+1(左子节点不为空得情况下)
  3. 第n个元素得右子节点为2*n+2(右子节点不为空得情况下)
  4. 第n个元素得父节点为(n-1)/2
2、前序遍历

和之前讲得二叉树得遍历一样,只是遍历得逻辑条件需要变化一些

顺序为:1 2 4 5 3 6 7

代码实现:

public static void preOrder(int index, int[] nums) { System.out.println(nums[index]); if (nums.length > 2 * index + 1) { preOrder(2 * index + 1, nums); } if (nums.length > 2 * index + 2) { preOrder(2 * index + 2, nums); }}3、中序遍历

和之前讲得二叉树得遍历一样,只是遍历得逻辑条件需要变化一些

顺序为:4 2 5 1 6 3 7

代码实现:

public static void inOrder(int index, int[] nums) { if (nums.length > 2 * index + 1) { inOrder(2 * index + 1, nums); } System.out.println(nums[index]); if (nums.length > 2 * index + 2) { inOrder(2 * index + 2, nums); }}4、后序遍历

和之前讲得二叉树得遍历一样,只是遍历得逻辑条件需要变化一些

顺序为:4 5 2 6 7 3 1

代码实现:

public static void postOrder(int index, int[] nums) { if (nums.length > 2 * index + 1) { postOrder(2 * index + 1, nums); } if (nums.length > 2 * index + 2) { postOrder(2 * index + 2, nums); } System.out.println(nums[index]);}

 
(文/尚优璐)
打赏
免责声明
• 
本文为尚优璐原创作品•作者: 尚优璐。欢迎转载,转载请注明原文出处:http://www.udxd.com/qysx/show-130747.html 。本文仅代表作者个人观点,本站未对其内容进行核实,请读者仅做参考,如若文中涉及有违公德、触犯法律的内容,一经发现,立即删除,作者需自行承担相应责任。涉及到版权或其他问题,请及时联系我们邮件:weilaitui@qq.com。
 

Copyright©2015-2023 粤公网安备 44030702000869号

粤ICP备16078936号

微信

关注
微信

微信二维码

WAP二维码

客服

联系
客服

联系客服:

24在线QQ: 770665880

客服电话: 020-82301567

E_mail邮箱: weilaitui@qq.com

微信公众号: weishitui

韩瑞 小英 张泽

工作时间:

周一至周五: 08:00 - 24:00

反馈

用户
反馈