二叉树遍历

1.先序遍历

遍历方式:遍历到一个节点后即输出该节点的值,并继续遍历该节点的左、右子树(简称:根左右)
图示
二叉树遍历_第1张图片
遍历结果:1 2 4 6 7 3 5 8 9

编码实现

(1)创建节点类

package com.company.algorithm;

public class TreeNode {
    int val;
    TreeNode left;
    TreeNode right;

    TreeNode() {

    }

    TreeNode(int val) {
        this.val = val;
    }

    TreeNode(int val, TreeNode left, TreeNode right) {
        this.val = val;
        this.left = left;
        this.right = right;
    }
}

(2)创建二叉树

package com.company.algorithm;

public class BinaryTree {
    public TreeNode[] BinaryTree(Integer[] array) {//建二叉树
        TreeNode root = new TreeNode(array[0]);//根节点
        TreeNode[] treeNodes = new TreeNode[array.length + 1];//二叉树所有根节点
        treeNodes[1] = root;
        for (int i = 2; i < treeNodes.length; i++) {
            if (array[i - 1] == null) continue;
            treeNodes[i] = new TreeNode(array[i - 1]);
            int parent = i / 2;//父节点索引值
            if (i % 2 == 0) {//左儿子
                treeNodes[parent].left = treeNodes[i];
            } else {//右儿子
                treeNodes[parent].right = treeNodes[i];
            }
        }
        return treeNodes;
    }
}

(3)非递归实现先序遍历

package com.company.algorithm;

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

public class PreOrderTraversal {
    public List<Integer> preOrder(TreeNode root) {
        List<Integer> list = new ArrayList<>();
        Stack<TreeNode> stack = new Stack<>();//将遍历后的节点保存到栈中
        TreeNode node = root;
        while (!stack.isEmpty() || node != null) {
            while (node != null) {//递归遍历左节点
                stack.push(node);
                list.add(node.val);
                node = node.left;
            }
            node = stack.pop();//直到左节点为null时,弹出栈顶元素
            node = node.right;//遍历父节点的右子节点
        }
        return list;
    }
}

(4)测试类

package com.company.algorithm;

import java.util.List;

public class PreOrderTest {
    public static void main(String[] args) {
        Integer[] nodes = new Integer[]{1, 2, 3, 4, null, null, 5, 6, 7, null, null, null, null, 8, 9};
        BinaryTree binaryTree = new BinaryTree();
        TreeNode[] treeNodes = binaryTree.BinaryTree(nodes);
        PreOrderTraversal preOrderTraversal = new PreOrderTraversal();
        List<Integer> list = preOrderTraversal.preOrder(treeNodes[1]);
        for (Integer integer : list)
            System.out.print(integer + "\t");
    }
}

(5)运行结果

D:\Java\JDK\bin\java.exe "-javaagent:D:\IntelliJ IDEA 2019.3.3\lib\idea_rt.jar=5214:D:\IntelliJ IDEA 2019.3.3\bin" -Dfile.encoding=UTF-8 -classpath D:\Java\JDK\jre\lib\charsets.jar;D:\Java\JDK\jre\lib\deploy.jar;D:\Java\JDK\jre\lib\ext\access-bridge-64.jar;D:\Java\JDK\jre\lib\ext\cldrdata.jar;D:\Java\JDK\jre\lib\ext\dnsns.jar;D:\Java\JDK\jre\lib\ext\jaccess.jar;D:\Java\JDK\jre\lib\ext\jfxrt.jar;D:\Java\JDK\jre\lib\ext\localedata.jar;D:\Java\JDK\jre\lib\ext\nashorn.jar;D:\Java\JDK\jre\lib\ext\sunec.jar;D:\Java\JDK\jre\lib\ext\sunjce_provider.jar;D:\Java\JDK\jre\lib\ext\sunmscapi.jar;D:\Java\JDK\jre\lib\ext\sunpkcs11.jar;D:\Java\JDK\jre\lib\ext\zipfs.jar;D:\Java\JDK\jre\lib\javaws.jar;D:\Java\JDK\jre\lib\jce.jar;D:\Java\JDK\jre\lib\jfr.jar;D:\Java\JDK\jre\lib\jfxswt.jar;D:\Java\JDK\jre\lib\jsse.jar;D:\Java\JDK\jre\lib\management-agent.jar;D:\Java\JDK\jre\lib\plugin.jar;D:\Java\JDK\jre\lib\resources.jar;D:\Java\JDK\jre\lib\rt.jar;D:\JavaWorkSpace\day11\out\production\algorithm com.company.algorithm.PreOrderTest
1	2	4	6	7	3	5	8	9	
Process finished with exit code 0

2.中序遍历

遍历方式:遍历到一个节点后,暂存该节点的值,遍历完该节点的左子树后,输出该节点的值,然后遍历该节点的右子树(简称:左根右)
图示
二叉树遍历_第2张图片
遍历结果:6 4 7 2 1 3 8 5 9

代码实现

(1)创建节点类

package com.company.algorithm;

public class TreeNode {
    int val;
    TreeNode left;
    TreeNode right;

    TreeNode() {

    }

    TreeNode(int val) {
        this.val = val;
    }

    TreeNode(int val, TreeNode left, TreeNode right) {
        this.val = val;
        this.left = left;
        this.right = right;
    }
}

(2)创建二叉树

package com.company.algorithm;

public class BinaryTree {
    public TreeNode[] BinaryTree(Integer[] array) {//建二叉树
        TreeNode root = new TreeNode(array[0]);//根节点
        TreeNode[] treeNodes = new TreeNode[array.length + 1];//二叉树所有根节点
        treeNodes[1] = root;
        for (int i = 2; i < treeNodes.length; i++) {
            if (array[i - 1] == null) continue;
            treeNodes[i] = new TreeNode(array[i - 1]);
            int parent = i / 2;//父节点索引值
            if (i % 2 == 0) {//左儿子
                treeNodes[parent].left = treeNodes[i];
            } else {//右儿子
                treeNodes[parent].right = treeNodes[i];
            }
        }
        return treeNodes;
    }
}

(3)非递归实现中序遍历

package com.company.algorithm;

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

public class MidOrderTraversal {
    public List<Integer> midOrder(TreeNode root) {
        List<Integer> list = new ArrayList<>();//保存遍历后的节点值
        Stack<TreeNode> stack = new Stack<>();
        TreeNode node = root;
        while (!stack.isEmpty() || node != null) {
            while (node != null) {//找最左边的子节点
                stack.push(node);
                node = node.left;
            }
            node = stack.pop();//返回当前节点的父节点
            list.add(node.val);
            node = node.right;
        }
        return list;
    }
}

(4)测试类

package com.company.algorithm;
package com.company.algorithm;

import java.util.List;

public class MidOrderTest {
    public static void main(String[] args) {
        Integer[] nodes = new Integer[]{1, 2, 3, 4, null, null, 5, 6, 7, null, null, null, null, 8, 9};
        BinaryTree binaryTree = new BinaryTree();
        TreeNode[] treeNodes = binaryTree.BinaryTree(nodes);
        MidOrderTraversal midOrderTraversal = new MidOrderTraversal();
        List<Integer> list = midOrderTraversal.midOrder(treeNodes[1]);
        for (Integer integer : list)
            System.out.print(integer + "\t");
    }
}

(5)运行结果

D:\Java\JDK\bin\java.exe "-javaagent:D:\IntelliJ IDEA 2019.3.3\lib\idea_rt.jar=6268:D:\IntelliJ IDEA 2019.3.3\bin" -Dfile.encoding=UTF-8 -classpath D:\Java\JDK\jre\lib\charsets.jar;D:\Java\JDK\jre\lib\deploy.jar;D:\Java\JDK\jre\lib\ext\access-bridge-64.jar;D:\Java\JDK\jre\lib\ext\cldrdata.jar;D:\Java\JDK\jre\lib\ext\dnsns.jar;D:\Java\JDK\jre\lib\ext\jaccess.jar;D:\Java\JDK\jre\lib\ext\jfxrt.jar;D:\Java\JDK\jre\lib\ext\localedata.jar;D:\Java\JDK\jre\lib\ext\nashorn.jar;D:\Java\JDK\jre\lib\ext\sunec.jar;D:\Java\JDK\jre\lib\ext\sunjce_provider.jar;D:\Java\JDK\jre\lib\ext\sunmscapi.jar;D:\Java\JDK\jre\lib\ext\sunpkcs11.jar;D:\Java\JDK\jre\lib\ext\zipfs.jar;D:\Java\JDK\jre\lib\javaws.jar;D:\Java\JDK\jre\lib\jce.jar;D:\Java\JDK\jre\lib\jfr.jar;D:\Java\JDK\jre\lib\jfxswt.jar;D:\Java\JDK\jre\lib\jsse.jar;D:\Java\JDK\jre\lib\management-agent.jar;D:\Java\JDK\jre\lib\plugin.jar;D:\Java\JDK\jre\lib\resources.jar;D:\Java\JDK\jre\lib\rt.jar;D:\JavaWorkSpace\day11\out\production\algorithm com.company.algorithm.MidOrderTest
6	4	7	2	1	3	8	5	9	
Process finished with exit code 0


3.后续遍历

遍历方式:遍历到一个节点后,暂存该节点的值,然后分别遍历该节点的左、右子树,最后输出该节点的值(简称:左右根)
图示
二叉树遍历_第3张图片
遍历结果:6 7 4 2 8 9 5 3 1

代码实现

(1)创建节点类

package com.company.algorithm;

public class TreeNode {
    int val;
    TreeNode left;
    TreeNode right;

    TreeNode() {

    }

    TreeNode(int val) {
        this.val = val;
    }

    TreeNode(int val, TreeNode left, TreeNode right) {
        this.val = val;
        this.left = left;
        this.right = right;
    }
}

(2)创建二叉树

package com.company.algorithm;

public class BinaryTree {
    public TreeNode[] BinaryTree(Integer[] array) {//建二叉树
        TreeNode root = new TreeNode(array[0]);//根节点
        TreeNode[] treeNodes = new TreeNode[array.length + 1];//二叉树所有根节点
        treeNodes[1] = root;
        for (int i = 2; i < treeNodes.length; i++) {
            if (array[i - 1] == null) continue;
            treeNodes[i] = new TreeNode(array[i - 1]);
            int parent = i / 2;//父节点索引值
            if (i % 2 == 0) {//左儿子
                treeNodes[parent].left = treeNodes[i];
            } else {//右儿子
                treeNodes[parent].right = treeNodes[i];
            }
        }
        return treeNodes;
    }
}

(3)非递归实现后序遍历

package com.company.algorithm;

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

public class AfterOrderTraversal {
    public List<Integer> afterOrder(TreeNode root) {
        List<Integer> list = new ArrayList<>();
        Stack<TreeNode> stack = new Stack<>();//保存遍历的中间节点
        Stack<TreeNode> out = new Stack<>();//保存压栈的节点值(压栈:根右左-出栈:左右根)
        TreeNode node = root;
        while (!stack.isEmpty() || node != null) {
            while (node != null) {
                stack.push(node);
                out.push(node);
                node = node.right;
            }
            node = stack.pop();
            node = node.left;
        }
        while (!out.isEmpty()) {
            list.add(out.pop().val);//保存后续遍历的节点顺序
        }
        return list;
    }
}

(4)测试类

package com.company.algorithm;

import java.util.List;

public class AfterOrderTest {
    public static void main(String[] args) {
        Integer[] nodes = new Integer[]{1, 2, 3, 4, null, null, 5, 6, 7, null, null, null, null, 8, 9};
        BinaryTree binaryTree = new BinaryTree();
        TreeNode[] treeNodes = binaryTree.BinaryTree(nodes);
        AfterOrderTraversal afterOrderTraversal = new AfterOrderTraversal();
        List<Integer> list = afterOrderTraversal.afterOrder(treeNodes[1]);
        for (Integer integer : list)
            System.out.print(integer + "\t");
    }
}

(5)运行结果

D:\Java\JDK\bin\java.exe "-javaagent:D:\IntelliJ IDEA 2019.3.3\lib\idea_rt.jar=6915:D:\IntelliJ IDEA 2019.3.3\bin" -Dfile.encoding=UTF-8 -classpath D:\Java\JDK\jre\lib\charsets.jar;D:\Java\JDK\jre\lib\deploy.jar;D:\Java\JDK\jre\lib\ext\access-bridge-64.jar;D:\Java\JDK\jre\lib\ext\cldrdata.jar;D:\Java\JDK\jre\lib\ext\dnsns.jar;D:\Java\JDK\jre\lib\ext\jaccess.jar;D:\Java\JDK\jre\lib\ext\jfxrt.jar;D:\Java\JDK\jre\lib\ext\localedata.jar;D:\Java\JDK\jre\lib\ext\nashorn.jar;D:\Java\JDK\jre\lib\ext\sunec.jar;D:\Java\JDK\jre\lib\ext\sunjce_provider.jar;D:\Java\JDK\jre\lib\ext\sunmscapi.jar;D:\Java\JDK\jre\lib\ext\sunpkcs11.jar;D:\Java\JDK\jre\lib\ext\zipfs.jar;D:\Java\JDK\jre\lib\javaws.jar;D:\Java\JDK\jre\lib\jce.jar;D:\Java\JDK\jre\lib\jfr.jar;D:\Java\JDK\jre\lib\jfxswt.jar;D:\Java\JDK\jre\lib\jsse.jar;D:\Java\JDK\jre\lib\management-agent.jar;D:\Java\JDK\jre\lib\plugin.jar;D:\Java\JDK\jre\lib\resources.jar;D:\Java\JDK\jre\lib\rt.jar;D:\JavaWorkSpace\day11\out\production\algorithm com.company.algorithm.AfterOrderTest
6	7	4	2	8	9	5	3	1	
Process finished with exit code 0

你可能感兴趣的:(数据结构,数据结构)