java 二叉树遍历算法

2022-01-11  本文已影响0人  Bfmall

二叉树的遍历可以分为先序、中序、后序、层次遍历。

前序遍历,遍历节点的顺序为:根—>左—>右;
中序遍历,遍历节点的顺序为:左—>根—>右;
后序遍历,遍历节点的顺序为:左—>右—>根。

递归方式代码实现如下:

import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;

import androidx.annotation.Nullable;
import androidx.appcompat.app.AppCompatActivity;

import com.example.nqct.R;

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

/**
 * DESC   : 二叉树排序
 */
public class TreeSortTestActivity extends AppCompatActivity {
    private static final String TAG = TreeSortTestActivity.class.getName();
    private TextView preOrderTv;
    private TextView middleOrderTv;
    private TextView afterOrderTv;
    private List<String> preOrderList = new ArrayList<>();
    private List<String> middleOrderList = new ArrayList<>();
    private List<String> postOrderList = new ArrayList<>();
    private Button middleSortBtn;

    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_tree_sort_test);
        preOrderTv = findViewById(R.id.tv_pre_order);
        middleOrderTv = findViewById(R.id.tv_middle_order);
        afterOrderTv = findViewById(R.id.tv_after_order);
        middleSortBtn = findViewById(R.id.btn_middle_sort);

        /**
         * 二叉树如下:
         *                    A
         *                  |   \
         *                |       \
         *              B          C
         *            |   \       |  \
         *           D     E     F   G
         *          | \    |
         *         H   I  J
         *
         * 先序遍历结果(根左右):A、B、D、H、I、E、J、C、F、G
         * 中序遍历结果(左根右):H、D、I、B、J、E、A、F、C、G
         * 后序遍历结果(左右根):H、I、D、J、E、B、F、G、C、A
         */

        TreeNode nodeA = new TreeNode("A");
        TreeNode nodeB = new TreeNode("B");
        TreeNode nodeC = new TreeNode("C");
        TreeNode nodeD = new TreeNode("D");
        TreeNode nodeE = new TreeNode("E");
        TreeNode nodeF = new TreeNode("F");
        TreeNode nodeG = new TreeNode("G");
        TreeNode nodeH = new TreeNode("H");
        TreeNode nodeI = new TreeNode("I");
        TreeNode nodeJ = new TreeNode("J");
        nodeA.left = nodeB;
        nodeA.right = nodeC;
        nodeB.left = nodeD;
        nodeB.right = nodeE;
        nodeD.left = nodeH;
        nodeD.right = nodeI;
        nodeE.left = nodeJ;
        nodeC.left = nodeF;
        nodeC.right = nodeG;

        //先序
        preSort(nodeA);
        if (preOrderList != null && !preOrderList.isEmpty()) {
            preOrderTv.setText("先序遍历结果:"+preOrderList.toString());
        }

        //中序
        middleSort(nodeA);
        if (middleOrderList != null && !middleOrderList.isEmpty()) {
            middleOrderTv.setText("中序遍历结果:"+middleOrderList.toString());
        }

        //后序
        postSort(nodeA);
        if (postOrderList != null && !postOrderList.isEmpty()) {
            afterOrderTv.setText("后序遍历结果:"+postOrderList.toString());
        }

        middleSortBtn.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {
                middleOrderList.clear();
                middleSort(nodeA);
                if (middleOrderList != null && !middleOrderList.isEmpty()) {
                    middleOrderTv.setText("中序遍历结果:"+middleOrderList.toString());
                }
            }
        });
    }

    /**
     * 先序遍历:根左右
     */
    private void preSort(TreeNode node) {
        if (node != null) {
            Log.d(TAG, "preSort==>value="+node.value);
            preOrderList.add(node.value);
            if (node.left != null) {
                preSort(node.left);
            }
            if (node.right != null) {
                preSort(node.right);
            }
        }
    }

    /**
     * 中序遍历:左根右
     * @param node
     */
    private void middleSort(TreeNode node) {
        if (node != null) {
            if (node.left != null) {
                middleSort(node.left);
                Log.d(TAG, "middleSort==>node left..."+node.left.value);
            }
            Log.d(TAG, "middleSort==>node.value="+node.value);
            middleOrderList.add(node.value);
            if (node.right != null) {
                middleSort(node.right);
                Log.d(TAG, "middleSort==>node right..."+node.right.value);
            }
        }
    }

    /**
     * 后序遍历:左右根
     * @param node
     */
    private void postSort(TreeNode node) {
        if (node != null) {
            if (node.left != null) {
                postSort(node.left);
                Log.d(TAG, "postSort==>node left..."+node.left.value);
            }
            if (node.right != null) {
                postSort(node.right);
                Log.d(TAG, "postSort==>node right..."+node.right.value);
            }
            Log.d(TAG, "postSort==>node.value="+node.value);
            postOrderList.add(node.value);
        }
    }


    public class TreeNode {
        public String value;
        public TreeNode left;
        public TreeNode right;

        public TreeNode(String value) {
            this.value = value;
        }
    }

}
上一篇下一篇

猜你喜欢

热点阅读