Scan tree structure from bottom up?

前端 未结 3 763
广开言路
广开言路 2021-02-08 10:23

If given the following tree structure or one similar to it:

\"enter

I would want t

3条回答
  •  别跟我提以往
    2021-02-08 11:03

    If you are maintaining an ArrayList (say node_list) to track the number of nodes branching of from the current tree node, you can traverse the tree from the root till you find a node that has an empty node_list. This way you will be able to identify the leaf nodes of the tree. A recursive approach would work for this case. I haven't tested the code but I believe this should work for what you have asked:

    If you are maintaining something similar to the class below to build your tree:

    class Node {
         String data;
         ArrayList node_list;}
    

    The following recursive function might be what you are looking for:

    public void traverse_tree(Node n){
        if(n.node_list.isEmpty()){
            System.out.print(n.data);
        }
        else{
            for(Node current_node:n.node_list){
                traverse_tree(current_node);
            }
            System.out.println(n.data);
        }
    }
    

    Essentially what you are looking at is the Post-order Depth First traversal of the tree.

提交回复
热议问题