当前位置: 首页 > news >正文

靠比较软件下载大全app网站珠海seo推广

靠比较软件下载大全app网站,珠海seo推广,WordPress自动搜索文章插件,设计图室内效果图文章目录 目录 文章目录 前言 一 . 什么是顺序存储二叉树 二 . 模拟实现 前序遍历 总结 前言 大家好,今天给大家讲一下顺序存储二叉树 一 . 什么是顺序存储二叉树 顺序存储二叉树是一种将二叉树的节点按照从上到下、从左到右的顺序存储在数组中的方法。具体来说,顺…

文章目录

目录

文章目录

前言

一 . 什么是顺序存储二叉树

二 . 模拟实现

前序遍历

总结


前言

大家好,今天给大家讲一下顺序存储二叉树


一 . 什么是顺序存储二叉树

顺序存储二叉树是一种将二叉树的节点按照从上到下、从左到右的顺序存储在数组中的方法。具体来说,顺序存储二叉树将二叉树的根节点存储在数组的第一个位置,然后按照从上到下、从左到右的顺序将二叉树的其他节点依次存储在数组中。

对于任意一个节点的索引为i(i从1开始),其左子节点的索引为2i右子节点的索引为2i+1。这样,通过数组的索引关系,可以方便地找到节点的父节点、左子节点和右子节点。

顺序存储二叉树的优点是可以使用数组的随机访问特性快速找到节点,不需要通过指针进行遍历。缺点是当二叉树的节点数较少时,可能会浪费较多的存储空间。此外,如果二叉树需要进行频繁的插入和删除操作,顺序存储二叉树的效率会较低。

 顺序存储二叉树的特点:

1)顺序二叉树通常只考虑完全二叉树

2)n个元素的左子节点为  2 * n + 1

3)n个元素的右子节点为  2 * n + 2

4)n个元素的父节点为  (n-1) / 2

5)n : 表示二叉树中的第几个元素(0开始编号如上图所示)

二 . 模拟实现

准备工作

// 编写一个ArrBinaryTree类,实现顺序存储二叉树遍历
class ArrBinaryTree{private int[] arr;// 存放数据节点的数组public ArrBinaryTree(int[] arr){this.arr = arr;}}
需求: 给你一个数组{1,2,3,4,5,6,7} 要求以二叉树前中后序遍历的方式进行遍历

前序遍历

思路分析

  1. 定义一个指针变量index,初始值为1,表示从根节点开始遍历。
  2. 从数组中取出索引为index的节点,并对其进行操作(如打印节点值)。
  3. 将index的值更新为其左子节点的索引,即index = 2 * index。
  4. 重复步骤2和步骤3,直到index超出数组的范围或者取出的节点为空。
  5. 如果index超出数组的范围,则遍历结束;否则,将index的值更新为其右子节点的索引,即index = 2 * index + 1。
  6. 重复步骤2到步骤5,直到index超出数组的范围。

代码实现

    public void preOrder(int index){// 如果数组为空或array.length == 0,直接返回if(arr == null || arr.length == 0){System.out.println("二叉树为空");return;}System.out.println(arr[index]);// 左递归if(index*2+1 < arr.length){preOrder(2*index+1);}// 右递归if(index*2+2 < arr.length){preOrder(index*2 +2);}}

 过程图解

 中序遍历和后序遍历过程和上图无本质区别,直接看代码

 /*** 顺序存储二叉树中序遍历* @param index 数组下标*/public void infixOrder(int index) {// 如果数组为空或array.length == 0,直接返回if (arr == null || arr.length == 0) {System.out.println("二叉树为空");return;}// 左递归if(index*2+1 < arr.length){preOrder(2*index+1);}System.out.println(arr[index]);// 右递归if(index*2+2 < arr.length){preOrder(index*2 +2);}}/*** 顺序存储二叉树后序遍历* @param index 数组下标*/public void postOrder(int index){// 如果数组为空或array.length == 0,直接返回if (arr == null || arr.length == 0) {System.out.println("二叉树为空");return;}// 左递归if(index*2+1 < arr.length){preOrder(2*index+1);}if(index*2+2 < arr.length){preOrder(index*2 +2);}System.out.println(arr[index]);// 右递归}


总结

大家根据图解过程应该很好理解,没什么难点,我们下一篇博客见。

http://www.ds6.com.cn/news/34255.html

相关文章:

  • 做网站新闻移动动态网络营销推广方案ppt
  • 音乐主题wordpress湖南关键词优化排名推广
  • 做铝材什么什么网站好山东建站管理系统
  • 做a短视频网站产品免费推广网站有哪些
  • 时时彩做号网站学it需要什么学历基础
  • 做网站的服务器还需要空间吗郑州百度关键词seo
  • 太原市住房和城乡建设厅网站沈阳线上教学
  • 网站策划书我与音乐网站建设与管理属于什么专业
  • 门户网站 开发注意免费下载官方百度
  • wordpress二次开发手册chm百度seo怎么操作
  • 品牌商城网站建设营销文案
  • 河北省省住房和城乡建设厅网站百度高级搜索入口
  • 金泉网是做网站的吗关键词seo排名
  • 做威客网站有何前途指数基金怎么选
  • 上线了做网站价格贵北京seo公司工作
  • asp网站开发的背景与环境深圳网站关键词优化公司
  • 做venn图的网站seo优化是怎么回事呢
  • 潍坊专业网站建设哪家好产品软文范例1000字
  • url对网站有威胁怎么办上海网络推广服务
  • 网站制作公司新鸿儒宁波seo网页怎么优化
  • 做袜子娃娃的网站网络营销案例分析题及答案
  • seo职位描述天津seo培训
  • 武汉网站制作案例seo公司培训课程
  • 惠州做网站小程序seo引擎优化外包公司
  • 网站时间轴网络营销推广服务商
  • 昌平区事业单位公共知识培训网站网站推广工具有哪些
  • 网站建设与维护毕业论文安徽网络推广
  • 公司介绍网站模板百度产品大全首页
  • 标准网站sitemap.xml中小企业管理培训课程
  • 专业小程序开发定制公司sem优化服务公司