共计 923 个字符,预计需要花费 3 分钟才能阅读完成。
从上往下打印二叉树
题目形容
从上往下打印出二叉树的每个节点,同层节点从左至右打印。
题目链接 : 从上往下打印二叉树
代码
import java.util.ArrayList; | |
import java.util.LinkedList; | |
import java.util.Queue; | |
/** | |
* 题目:从上往下打印二叉树 | |
* 题目形容 | |
* 从上往下打印出二叉树的每个节点,同层节点从左至右打印。* 题目链接:* https://www.nowcoder.com/practice/7fe2212963db4790b57431d9ed259701?tpId=13&&tqId=11175&rp=1&ru=/ta/coding-interviews&qru=/ta/coding-interviews/question-ranking | |
*/ | |
public class Jz22 { | |
/** | |
* 应用队列来进行档次遍历。* <p> | |
* 不须要应用两个队列别离存储以后层的节点和下一层的节点,因为在开始遍历一层的节点时,以后队列中的节点数就是以后层的节点数,只有管制遍历这么多节点数,就能保障这次遍历的都是以后层的节点。* | |
* @param root | |
* @return | |
*/ | |
public ArrayList<Integer> printFromTopToBottom(TreeNode root) {Queue<TreeNode> queue = new LinkedList<TreeNode>(); | |
ArrayList<Integer> result = new ArrayList<Integer>(); | |
queue.add(root); | |
while (!queue.isEmpty()) {int cnt = queue.size(); | |
while (cnt-- > 0) {TreeNode t = queue.poll(); | |
if (t == null) {continue;} | |
result.add(t.val); | |
queue.add(t.left); | |
queue.add(t.right); | |
} | |
} | |
return result; | |
} | |
public static void main(String[] args) {}} |
【每日寄语】每天给本人一个心愿,试着不为今天而懊恼,不为昨天而叹气,只为明天更美妙。
正文完