二叉树概念和实现

二叉树百度百科

二叉树的定义:二叉树是一个连通的无环图,并且每一个顶点的度不大于3。有根二叉树还要满足根结点的度不大于2。有了根结点之后,每个顶点定义了唯一的父结点,和最多2个子结点。然而,没有足够的信息来区分左结点和右结点。如果不考虑连通性,允许图中有多个连通分量,这样的结构叫做森林。

二叉树使用二叉链表的实现:

package algorithm;

/**
 * 二叉链表
 */
public class BiTNode<T> {
    // 数据
    T data;

    // 左孩子节点
    BiTNode lchild;
    // 右孩子节点
    BiTNode rchild;

    public T getData() {
        return data;
    }

    public void setData(T data) {
        this.data = data;
    }

    public BiTNode getLchild() {
        return lchild;
    }

    public void setLchild(BiTNode lchild) {
        this.lchild = lchild;
    }

    public BiTNode getRchild() {
        return rchild;
    }

    public void setRchild(BiTNode rchild) {
        this.rchild = rchild;
    }
}

二叉树的遍历:

package algorithm;

import java.util.ArrayList;
import java.util.List;

/**
 * 二叉链表工具类
 */
public class BiTNodeUtil {

    /**
     * 前序遍历
     * 从二叉树的根结点出发,当第一次到达结点时就输出结点数据,按照先向左在向右的方向访问。
     */
    public static String preorderTraversal(BiTNode biTNode) {
        String traversal = "";
        // 先遍历根节点
        if (biTNode != null) {
            traversal += biTNode.getData();
            traversal += preorderTraversal(biTNode.getLchild());
            traversal += preorderTraversal(biTNode.getRchild());
        }
        return traversal;
    }

    /**
     * 中序遍历
     * 从二叉树的根结点出发,当第二次到达结点时就输出结点数据,按照先向左在向右的方向访问。
     */
    public static String sequentialTraversal(BiTNode biTNode) {
        String traversal = "";
        // 先遍历左节点
        if (biTNode != null ) {
            traversal += sequentialTraversal(biTNode.getLchild());
            traversal += biTNode.getData();
            traversal += sequentialTraversal(biTNode.getRchild());
        }
        return traversal;
    }

    /**
     * 后序遍历
     * 从二叉树的根结点出发,当第三次到达结点时就输出结点数据,按照先向左在向右的方向访问。
     */
    public static String postOrderTraversal(BiTNode biTNode) {
        String traversal = "";
        // 先遍历左节点
        if (biTNode != null ) {
            traversal += postOrderTraversal(biTNode.getLchild());
            traversal += postOrderTraversal(biTNode.getRchild());
            traversal += biTNode.getData();
        }
        return traversal;
    }

    /**
     * 层序遍历
     * 按照树的层次自上而下的遍历二叉树。
     */
    public static String layerTraversal(BiTNode biTNode){
        String traversal = "";
        // 创建一个队列
        List<BiTNode> biTNodeList = new ArrayList<BiTNode>();
        // 初始化队列
        if (biTNode == null) {
            return traversal;
        }
        biTNodeList.add(biTNode);
        // 初始化定位数据
        int per = 0;
        int tail = biTNodeList.size();
        while (per < tail) {
            BiTNode curr = biTNodeList.get(per);
            traversal += curr.getData();
            if (curr.getLchild() != null) {
                biTNodeList.add(curr.getLchild());
            }
            if (curr.getRchild() != null) {
                biTNodeList.add(curr.getRchild());
            }
            // 刷新定位数据,per向后移动一位,tail更新为最新队列大小。
            per++;
            tail = biTNodeList.size();
        }
        return traversal;
    }

    public static void main(String[] args) {
        BiTNode<String> a = new BiTNode<String>();
        a.setData("a");
        BiTNode<String> b = new BiTNode<String>();
        b.setData("b");
        BiTNode<String> c = new BiTNode<String>();
        c.setData("c");
        BiTNode<String> d = new BiTNode<String>();
        d.setData("d");
        BiTNode<String> e = new BiTNode<String>();
        e.setData("e");
        BiTNode<String> f = new BiTNode<String>();
        f.setData("f");
        BiTNode<String> g = new BiTNode<String>();
        g.setData("g");
        BiTNode<String> h = new BiTNode<String>();
        h.setData("h");
        BiTNode<String> i = new BiTNode<String>();
        i.setData("i");
        BiTNode<String> j = new BiTNode<String>();
        j.setData("j");
        a.setLchild(b);
        a.setRchild(c);
        b.setLchild(d);
        b.setRchild(e);
        c.setLchild(f);
        c.setRchild(g);
        d.setLchild(h);
        d.setRchild(i);
        e.setLchild(j);
        System.out.println("前序:" + preorderTraversal(a));
        System.out.println("中序:" + sequentialTraversal(a));
        System.out.println("后序:" + postOrderTraversal(a));
        System.out.println("层序:" + layerTraversal(a));
    }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值