LeetCode——Binary Tree Preorder Traversal
Given a binary tree, return the preorder traversal of its nodes' values.
For example:
Given binary tree {1,#,2,3},
1
\
2
/
3
return [1,2,3].
Note: Recursive solution is trivial, could you do it iteratively?
中文:二叉树的前序遍历(根-左-右)。
能用非递归实现吗?
递归:
public class BinaryTreePreorderTraversal {
    public List<Integer> preorderTraversal(TreeNode root) {
    	List<Integer> list = new ArrayList<Integer>();
        if(root == null)
        	return list;
        list.add(root.val);
        list.addAll(preorderTraversal(root.left));
        list.addAll(preorderTraversal(root.right));
        return list;
    }
    // Definition for binary tree
     public class TreeNode {
         int val;
         TreeNode left;
         TreeNode right;
         TreeNode(int x) { val = x; }
     }
}
非递归:先把右节点的值压入栈中,再压入左的。弹出左的,弹出右的……。
    public List<Integer> preorderTraversal(TreeNode root){
    	List<Integer> list = new ArrayList<Integer>();
    	if(root == null)
    		return list;
    	Stack<TreeNode> stack = new Stack<TreeNode>();
    	stack.push(root);
    	while(!stack.isEmpty()){
    		TreeNode node = stack.pop();
    		list.add(node.val);
    		if(node.right != null)
    			stack.push(node.right);
    		if(node.left != null)
    			stack.push(node.left);
    	}
    	return list;
    }
LeetCode——Binary Tree Preorder Traversal的更多相关文章
- LeetCode: Binary Tree Preorder Traversal  解题报告
		Binary Tree Preorder Traversal Given a binary tree, return the preorder traversal of its nodes' valu ... 
- [LeetCode] Binary Tree Preorder Traversal 二叉树的先序遍历
		Given a binary tree, return the preorder traversal of its nodes' values. For example:Given binary tr ... 
- [LeetCode] Binary Tree Preorder Traversal
		Given a binary tree, return the preorder traversal of its nodes' values. For example:Given binary tr ... 
- [leetcode]Binary Tree Preorder Traversal @ Python
		原题地址:http://oj.leetcode.com/problems/binary-tree-preorder-traversal/ 题意:这题用递归比较简单.应该考察的是使用非递归实现二叉树的先 ... 
- LeetCode Binary Tree Preorder Traversal  先根遍历
		题意:给一棵树,求其先根遍历的结果. 思路: (1)深搜法: /** * Definition for a binary tree node. * struct TreeNode { * int va ... 
- C++版 - LeetCode 144. Binary Tree Preorder Traversal (二叉树先根序遍历,非递归)
		144. Binary Tree Preorder Traversal Difficulty: Medium Given a binary tree, return the preorder trav ... 
- LeetCode 144. 二叉树的前序遍历(Binary Tree Preorder Traversal)
		144. 二叉树的前序遍历 144. Binary Tree Preorder Traversal 题目描述 给定一个二叉树,返回它的 前序 遍历. LeetCode144. Binary Tree ... 
- 【LeetCode】Binary Tree Preorder Traversal
		Binary Tree Preorder Traversal Given a binary tree, return the preorder traversal of its nodes' valu ... 
- Binary Tree Preorder Traversal on LeetCode in Java
		二叉树的非递归前序遍历,大抵是很多人信手拈来.不屑一顾的题目罢.然而因为本人记性不好.基础太差的缘故,做这道题的时候居然自己琢磨出了一种解法,虽然谈不上创新,但简单一搜也未发现雷同,权且记录,希望于人 ... 
随机推荐
- 1.2.1 工作流管理系统参考模型 (zhuan)
			http://book.51cto.com/art/201009/228705.htm ************************************************* <jB ... 
- js判断字符是否存在汉字的方法
			<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ... 
- oracle 实现插入自增列(类似SqlServer Identity)
			oracle不像sql server 有关键字identity直接可插入数据时自增 ,Oracle是不能用Identity,可以使用Sequence Create Table Tempinfo( id ... 
- 在jsp里面不要瞎用<!-- -->注释
			如图: SEVERE: Servlet.service() for servlet jsp threw exceptionorg.apache.jasper.JasperException: /ch1 ... 
- Unity Vector3.Slerp使用范例
			using System.Collections; using System.Collections.Generic; using UnityEngine; public class TestSler ... 
- C语言  ·  最大最小值
			算法提高 题目1 最大最小值 时间限制:1.0s 内存限制:1.0GB 问题描述 给定 N 个整数,请你找出这 N 个数中最大的那个和最小的那个. 输入格式 第一行包含一个正整数 N ... 
- UVA 11019 Matrix Matcher 矩阵匹配器 AC自动机 二维文本串查找二维模式串
			链接:https://vjudge.net/problem/UVA-11019lrjP218 matrix matcher #include<bits/stdc++.h> using na ... 
- hive thrift 开机启动
			这个问题困扰我很久,之前redis的时候,也出现了这个问题,从网上找的thrift脚本没有一个好使的,最后通过修改/etc/rc.d/rc.local来执行一些非服务的命令,这样子就不需要像写服务那样 ... 
- Entity Framework表拆分
			一.概念 表拆分:一个表拆分成多个实体,例如Photograph表,可以拆分为Photograph和PhotographFullImage两张表. Photograph实体结构: using Syst ... 
- zipkin使用mysql保存数据
			zipkin和mysql结合保存zipkin在项目监控中得到的所有数据. <dependency> <groupId>io.zipkin.java</groupId> ... 
