返回介绍

solution / 0500-0599 / 0589.N-ary Tree Preorder Traversal / README_EN

发布于 2024-06-17 01:03:59 字数 9310 浏览 0 评论 0 收藏 0

589. N-ary Tree Preorder Traversal

中文文档

Description

Given the root of an n-ary tree, return _the preorder 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: [1,3,5,6,2,4]

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: [1,2,3,6,7,11,14,4,8,12,5,9,13,10]

 

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?

Solutions

Solution 1: Recursion

We can recursively traverse the entire tree. For each node, we first add the node's value to the answer, then recursively call the function for each of the node's children.

The time complexity is $O(n)$, and the space complexity is $O(n)$. Here, $n$ is the number of nodes.

"""
# Definition for a Node.
class Node:
  def __init__(self, val=None, children=None):
    self.val = val
    self.children = children
"""


class Solution:
  def preorder(self, root: "Node") -> List[int]:
    def dfs(root):
      if root is None:
        return
      ans.append(root.val)
      for child in root.children:
        dfs(child)

    ans = []
    dfs(root)
    return ans
/*
// Definition for a Node.
class Node {
  public int val;
  public List<Node> children;

  public Node() {}

  public Node(int _val) {
    val = _val;
  }

  public Node(int _val, List<Node> _children) {
    val = _val;
    children = _children;
  }
};
*/

class Solution {
  private List<Integer> ans = new ArrayList<>();

  public List<Integer> preorder(Node root) {
    dfs(root);
    return ans;
  }

  private void dfs(Node root) {
    if (root == null) {
      return;
    }
    ans.add(root.val);
    for (Node child : root.children) {
      dfs(child);
    }
  }
}
/*
// Definition for a Node.
class Node {
public:
  int val;
  vector<Node*> children;

  Node() {}

  Node(int _val) {
    val = _val;
  }

  Node(int _val, vector<Node*> _children) {
    val = _val;
    children = _children;
  }
};
*/

class Solution {
public:
  vector<int> preorder(Node* root) {
    vector<int> ans;
    function<void(Node*)> dfs = [&](Node* root) {
      if (!root) {
        return;
      }
      ans.push_back(root->val);
      for (auto& child : root->children) {
        dfs(child);
      }
    };
    dfs(root);
    return ans;
  }
};
/**
 * Definition for a Node.
 * type Node struct {
 *   Val int
 *   Children []*Node
 * }
 */

func preorder(root *Node) (ans []int) {
  var dfs func(*Node)
  dfs = func(root *Node) {
    if root == nil {
      return
    }
    ans = append(ans, root.Val)
    for _, child := range root.Children {
      dfs(child)
    }
  }
  dfs(root)
  return
}
/**
 * Definition for node.
 * class Node {
 *   val: number
 *   children: Node[]
 *   constructor(val?: number) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.children = []
 *   }
 * }
 */

function preorder(root: Node | null): number[] {
  const ans: number[] = [];
  const dfs = (root: Node | null) => {
    if (!root) {
      return;
    }
    ans.push(root.val);
    for (const child of root.children) {
      dfs(child);
    }
  };
  dfs(root);
  return ans;
}
/**
 * Definition for a Node.
 * struct Node {
 *   int val;
 *   int numChildren;
 *   struct Node** children;
 * };
 */

/**
 * Note: The returned array must be malloced, assume caller calls free().
 */

void dfs(struct Node* root, int* ans, int* i) {
  if (!root) {
    return;
  }
  ans[(*i)++] = root->val;
  for (int j = 0; j < root->numChildren; j++) {
    dfs(root->children[j], ans, i);
  }
}

int* preorder(struct Node* root, int* returnSize) {
  int* ans = malloc(sizeof(int) * 10000);
  *returnSize = 0;
  dfs(root, ans, returnSize);
  return ans;
}

Solution 2: Iteration (Stack Implementation)

We can also solve this problem iteratively.

We use a stack to help us get the pre-order traversal. We first push the root node into the stack. Since the pre-order traversal is root, left subtree, right subtree, and the characteristic of the stack is first in last out, we first add the node's value to the answer, then push each of the node's children into the stack in the order from right to left. We continue this process until the stack is empty.

The time complexity is $O(n)$, and the space complexity is $O(n)$. Here, $n$ is the number of nodes.

"""
# Definition for a Node.
class Node:
  def __init__(self, val=None, children=None):
    self.val = val
    self.children = children
"""


class Solution:
  def preorder(self, root: 'Node') -> List[int]:
    ans = []
    if root is None:
      return ans
    stk = [root]
    while stk:
      node = stk.pop()
      ans.append(node.val)
      for child in node.children[::-1]:
        stk.append(child)
    return ans
/*
// Definition for a Node.
class Node {
  public int val;
  public List<Node> children;

  public Node() {}

  public Node(int _val) {
    val = _val;
  }

  public Node(int _val, List<Node> _children) {
    val = _val;
    children = _children;
  }
};
*/

class Solution {
  public List<Integer> preorder(Node root) {
    if (root == null) {
      return Collections.emptyList();
    }
    List<Integer> ans = new ArrayList<>();
    Deque<Node> stk = new ArrayDeque<>();
    stk.push(root);
    while (!stk.isEmpty()) {
      Node node = stk.pop();
      ans.add(node.val);
      List<Node> children = node.children;
      for (int i = children.size() - 1; i >= 0; --i) {
        stk.push(children.get(i));
      }
    }
    return ans;
  }
}
/*
// Definition for a Node.
class Node {
public:
  int val;
  vector<Node*> children;

  Node() {}

  Node(int _val) {
    val = _val;
  }

  Node(int _val, vector<Node*> _children) {
    val = _val;
    children = _children;
  }
};
*/

class Solution {
public:
  vector<int> preorder(Node* root) {
    if (!root) return {};
    vector<int> ans;
    stack<Node*> stk;
    stk.push(root);
    while (!stk.empty()) {
      Node* node = stk.top();
      ans.push_back(node->val);
      stk.pop();
      auto children = node->children;
      for (int i = children.size() - 1; i >= 0; --i) stk.push(children[i]);
    }
    return ans;
  }
};
/**
 * Definition for a Node.
 * type Node struct {
 *   Val int
 *   Children []*Node
 * }
 */

func preorder(root *Node) (ans []int) {
  if root == nil {
    return
  }
  stk := []*Node{root}
  for len(stk) > 0 {
    node := stk[len(stk)-1]
    ans = append(ans, node.Val)
    stk = stk[:len(stk)-1]
    children := node.Children
    for i := len(children) - 1; i >= 0; i-- {
      stk = append(stk, children[i])
    }
  }
  return
}
/**
 * Definition for node.
 * class Node {
 *   val: number
 *   children: Node[]
 *   constructor(val?: number) {
 *     this.val = (val===undefined ? 0 : val)
 *     this.children = []
 *   }
 * }
 */

function preorder(root: Node | null): number[] {
  const ans: number[] = [];
  if (!root) {
    return ans;
  }
  const stk: Node[] = [root];
  while (stk.length) {
    const { val, children } = stk.pop()!;
    ans.push(val);
    for (let i = children.length - 1; i >= 0; i--) {
      stk.push(children[i]);
    }
  }
  return ans;
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文