java实现二叉树的链式存储结构、先序遍历建立二叉树、先序遍历二叉树

1、二叉树的数据结构:二叉链表

package BT;

public class BinearyTree {
        E data; 
        BinearyTree lchild;
        BinearyTree rchild;
        public BinearyTree(E data){
            this.data=data;
        }
}

2、先序建立二叉树:

java实现二叉树的链式存储结构、先序遍历建立二叉树、先序遍历二叉树_第1张图片java实现二叉树的链式存储结构、先序遍历建立二叉树、先序遍历二叉树_第2张图片

A B D * F * * * C E * * *:*代表为null

private static BinearyTree createBinaryTreeByPreorder(BinearyTree bt) {
        // TODO Auto-generated method stub
        System.out.println("请输入当前节点的数据域:");
         data=scan.nextLine();
         if(data.equals("*")){
             bt=null;
         }else{
             bt=new BinearyTree(data);
             bt.lchild= createBinaryTreeByPreorder(bt.lchild);
             bt.rchild= createBinaryTreeByPreorder(bt.rchild);
         }
         return bt;
    }

3、先序遍历二叉树

private static void preOrder(BinearyTree root) {
        // TODO Auto-generated method stub
        if(root!=null) {
            System.out.println(root.data);
            preOrder( root.lchild);
            preOrder( root.rchild);
        }
    }
4、测试代码:

public class CreateBinaryTreeByPreorder {
    static Scanner scan;
    static String data;
    static {scan=new Scanner(System.in);}

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        BinearyTree root = null;
        root=createBinaryTreeByPreorder(root);
        //System.out.println(root.lchild.data);
        preOrder(root);
    }

    private static void preOrder(BinearyTree root) {
        // TODO Auto-generated method stub
        if(root!=null) {
            System.out.println(root.data);
            preOrder( root.lchild);
            preOrder( root.rchild);
        }
    }

    private static BinearyTree createBinaryTreeByPreorder(BinearyTree bt) {
        // TODO Auto-generated method stub
        System.out.println("请输入当前节点的数据域:");
         data=scan.nextLine();
         if(data.equals("0")){
             bt=null;
         }else{
             bt=new BinearyTree(data);
             bt.lchild= createBinaryTreeByPreorder(bt.lchild);
             bt.rchild= createBinaryTreeByPreorder(bt.rchild);
         }
         return bt;
    } 
}
测试结果:

请输入当前节点的数据域:
A
请输入当前节点的数据域:
B
请输入当前节点的数据域:
D
请输入当前节点的数据域:
*
请输入当前节点的数据域:
F
请输入当前节点的数据域:
*
请输入当前节点的数据域:
*
请输入当前节点的数据域:
*
请输入当前节点的数据域:
*
请输入当前节点的数据域:
E
请输入当前节点的数据域:
*
请输入当前节点的数据域:
*
请输入当前节点的数据域:
*
A B D F C E 

你可能感兴趣的:(数据结构算法,数据结构二叉树的遍历)