博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LeetCode 590. N叉树的后序遍历(N-ary Tree Postorder Traversal)
阅读量:5096 次
发布时间:2019-06-13

本文共 1758 字,大约阅读时间需要 5 分钟。

590. N叉树的后序遍历

590. N-ary Tree Postorder Traversal

题目描述

给定一个 N 叉树,返回其节点值的后序遍历。

LeetCode590. N-ary Tree Postorder Traversal

例如,给定一个 3 叉树:

1306719-20190511190956824-346656002.png
返回其后序遍历: [5,6,3,2,4,1].

说明: 递归法很简单,你可以使用迭代法完成此题吗?

Java 实现

Iterative Solution

import java.util.LinkedList;import java.util.List;import java.util.Stack;class Node {    public int val;    public List
children; public Node() { } public Node(int _val, List
_children) { val = _val; children = _children; }}class Solution { public List
postorder(Node root) { List
result = new LinkedList<>(); if (root == null) { return result; } Stack
stack = new Stack<>(); stack.push(root); while (!stack.isEmpty()) { Node node = stack.pop(); for (Node child:node.children){ stack.push(child); } result.add(0, node.val); } return result; }}

Recursive Solution

import java.util.LinkedList;import java.util.List;class Node {    public int val;    public List
children; public Node() { } public Node(int _val, List
_children) { val = _val; children = _children; }}class Solution { List
result = new LinkedList<>(); public List
postorder(Node root) { if (root == null) { return result; } List
node = root.children; for (int i = 0; i < node.size(); i++) { postorder(node.get(i)); } result.add(root.val); return result; }}

相似题目

参考资料

转载于:https://www.cnblogs.com/hglibin/p/10850171.html

你可能感兴趣的文章
android中自定义下拉框(转)
查看>>
Android设计模式源码解析之外观模式(Facade)
查看>>
使用word发布博客
查看>>
面向对象的小demo
查看>>
微服务之初了解(一)
查看>>
GDOI DAY1游记
查看>>
收集WebDriver的执行命令和参数信息
查看>>
数据结构与算法(三)-线性表之静态链表
查看>>
mac下的mysql报错:ERROR 1045(28000)和ERROR 2002 (HY000)的解决办法
查看>>
Hmailserver搭建邮件服务器
查看>>
django之多表查询-2
查看>>
快速幂
查看>>
改善C#公共程序类库质量的10种方法
查看>>
AIO 开始不定时的抛异常: java.io.IOException: 指定的网络名不再可用
查看>>
MyBaits动态sql语句
查看>>
HDU4405(期望DP)
查看>>
拉格朗日乘子法 那些年学过的高数
查看>>
vs code 的便捷使用
查看>>
Spring MVC @ResponseBody返回中文字符串乱码问题
查看>>
用户空间与内核空间,进程上下文与中断上下文[总结]
查看>>