无锡梅村网站建设,北京 网站设计飞沐,凡科网可以免费做网站吗,公司网站需要程序员做吗一、题目描述给你二叉树的根节点 root #xff0c;返回它节点值的 前序 遍历。示例 1#xff1a;输入#xff1a;root [1,null,2,3]输出#xff1a;[1,2,3]示例 2#xff1a;输入#xff1a;root []输出#xff1a;[]示例 3#xff1a;输入#xff1a;root [1]输出…一、题目描述给你二叉树的根节点 root 返回它节点值的 前序 遍历。 示例 1输入root [1,null,2,3]输出[1,2,3]示例 2输入root []输出[]示例 3输入root [1]输出[1]示例 4输入root [1,2]输出[1,2]示例 5输入root [1,null,2]输出[1,2]来源力扣LeetCode链接https://leetcode.cn/problems/binary-tree-preorder-traversal著作权归领扣网络所有。商业转载请联系官方授权非商业转载请注明出处。二、运行结果递归方式运行结果非递归方式运行结果内存好像用得更多了.org三、解题思路主要说一下非递归方式需要使用一个栈java现在已经不推荐使用Stack类程序中用Deque模拟栈并且孩子结点进栈时是右孩子结点先进栈左孩子结点后进栈。四、AC代码递归方式代码/*** Definition for a binary tree node.* public class TreeNode {* int val;* TreeNode left;* TreeNode right;* TreeNode() {}* TreeNode(int val) { this.val val; }* TreeNode(int val, TreeNode left, TreeNode right) {* this.val val;* this.left left;* this.right right;* }* }*/
class Solution {ListInteger ans new ArrayList();public ListInteger preorderTraversal(TreeNode root) {if(root null) return ans;// 递归方式ans.add(root.val);preorderTraversal(root.left);preorderTraversal(root.right);return ans;}
}非递归方式代码class Solution {ListInteger ans new ArrayList();public ListInteger preorderTraversal(TreeNode root) {if(root null) return ans;// 非递归方式DequeTreeNode dt new LinkedList();dt.offer(root);while(!dt.isEmpty()){TreeNode tmp dt.removeLast();ans.add(tmp.val);if(tmp.right ! null) dt.offer(tmp.right);if(tmp.left ! null) dt.offer(tmp.left);}return ans;}
}