顺序存储二叉树(前序中序遍历)

 顺序存储二叉树特点:

将二叉树存储在一个数组中,通过下标有如下规律。

1.只考虑完全二叉树

2.第n个节点的左子节点为2*n+1

3.第n个节点的右子节点为2*n+2

4.第n个节点的父节点为(n-1)/2

package day18;
//顺序存储二叉树遍历(堆排序),将arr数组存储在二叉树中
public class arrBinaryDemo {
    public static void main(String[] args) {
         int [] arr={1,2,3,4,5,6,7};
        ArrBinarytree arrBinarytree = new ArrBinarytree(arr);
//        arrBinarytree.preorder();
        arrBinarytree.arrinfixorder(0);

    }

}
//编写一个树
class ArrBinarytree{
    private int[] arr;

    public ArrBinarytree(int[] arr) {
        this.arr = arr;
    }
//    重载perorder,使调用的代码更加简单。参数0直接写死在方法里面
    public void preorder(){
        this.preorder(0);
    }

    //前序遍历方法
    public void preorder(int index){ //index为数组的下标
        if (arr==null||arr.length==0){
            System.out.println( "数组为空");
        }
        //前序遍历  自己---左---右
        System.out.println(arr[index]);
        //向左递归遍历
        if (index*2+1<arr.length){
        preorder(index*2+1);
        }
//        向右
        if (index*2+2<arr.length){
            preorder(index*2+2);
        }

    }
//    中序遍历
    public void arrinfixorder(int index){
//       判断数组是否为空
        if (arr==null||arr.length==0){
            System.out.println("数组为空");
        }
//中序遍历顺序为左 ---中----右
        if (index*2+1<arr.length){
    arrinfixorder(index*2+1);
        }
        System.out.println(arr[index]);
        if (index*2+2<arr.length){
            arrinfixorder(index*2+2);
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值