590. N-ary Tree Postorder Traversal LeetCode Solution

In this guide, you will get 590. N-ary Tree Postorder Traversal LeetCode Solution with the best time and space complexity. The solution to N-ary Tree Postorder Traversal problem is provided in various programming languages like C++, Java, and Python. This will be helpful for you if you are preparing for placements, hackathons, interviews, or practice purposes. The solutions provided here are very easy to follow and include detailed explanations.

Table of Contents

  1. Problem Statement
  2. Complexity Analysis
  3. N-ary Tree Postorder Traversal solution in C++
  4. N-ary Tree Postorder Traversal solution in Java
  5. N-ary Tree Postorder Traversal solution in Python
  6. Additional Resources
590. N-ary Tree Postorder Traversal LeetCode Solution image

Problem Statement of N-ary Tree Postorder Traversal

Given the root of an n-ary tree, return the postorder traversal of its nodes’ values.
Nary-Tree input serialization is represented in their level order traversal. Each group of children is separated by the null value (See examples)

Example 1:

Input: root = [1,null,3,2,4,null,5,6]
Output: [5,6,3,2,4,1]

Example 2:

Input: root = [1,null,2,3,4,5,null,null,6,7,null,8,null,9,10,null,null,11,null,12,null,13,null,null,14]
Output: [2,6,14,11,7,3,12,8,4,13,9,10,5,1]

Constraints:

The number of nodes in the tree is in the range [0, 104].
0 <= Node.val <= 104
The height of the n-ary tree is less than or equal to 1000.

Follow up: Recursive solution is trivial, could you do it iteratively?

Complexity Analysis

  • Time Complexity: O(n)
  • Space Complexity: O(n)

590. N-ary Tree Postorder Traversal LeetCode Solution in C++

class Solution {
 public:
  vector<int> postorder(Node* root) {
    if (root == nullptr)
      return {};

    vector<int> ans;
    stack<Node*> stack{{root}};

    while (!stack.empty()) {
      root = stack.top(), stack.pop();
      ans.push_back(root->val);
      for (Node* child : root->children)
        stack.push(child);
    }

    ranges::reverse(ans);
    return ans;
  }
};
/* code provided by PROGIEZ */

590. N-ary Tree Postorder Traversal LeetCode Solution in Java

class Solution {
  public List<Integer> postorder(Node root) {
    if (root == null)
      return new ArrayList<>();

    List<Integer> ans = new ArrayList<>();
    Deque<Node> stack = new ArrayDeque<>();
    stack.push(root);

    while (!stack.isEmpty()) {
      root = stack.pop();
      ans.add(root.val);
      for (Node child : root.children)
        stack.push(child);
    }

    Collections.reverse(ans);
    return ans;
  }
}
// code provided by PROGIEZ

590. N-ary Tree Postorder Traversal LeetCode Solution in Python

N/A
# code by PROGIEZ

Additional Resources

See also  215. Kth Largest Element in an Array LeetCode Solution

Happy Coding! Keep following PROGIEZ for more updates and solutions.