2018-11-01-weekly
Algorithm
-
What 给定一个二叉树,返回其节点值自底向上的层次遍历。 (即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历)。例如:给定二叉树 [3,9,20,null,null,15,7],返回其自底向上的层次遍历为:[[15,7],[9,20],[3]]
-
How 利用队列进行遍历,将每一层的元素入队,循环将该层元素的值存入栈中,并把每一轮得到的左右儿子分别存入队列中再次循环,最后将栈中的元素弹出,从而使各个分数组逆序排列。
-
Key Codes
/**
* Definition for a binary tree node.
* public class TreeNode {
* int val;
* TreeNode left;
* TreeNode right;
* TreeNode(int x) { val = x; }
* }
*/
class Solution {
public List<List<Integer>> levelOrderBottom(TreeNode root) {
Queue<TreeNode> queue = new LinkedList<TreeNode>();
Stack<List<Integer>> visited = new Stack<List<Integer>>();
List<List<Integer>> ans = new LinkedList<List<Integer>>();
if (root != null) {
queue.offer(root);
}
else {
return visited;
}
while (!queue.isEmpty()) {
int level = queue.size();
List<Integer> temp_visited = new LinkedList<Integer>();
for (int i = 0; i < level; i++) {
if (queue.peek().left != null) {
queue.offer(queue.peek().left);
}
if (queue.peek().right != null) {
queue.offer(queue.peek().right);
}
temp_visited.add(queue.poll().val);
}
visited.push(temp_visited);
}
while (!visited.isEmpty()) {
ans.add(visited.pop());
}
return ans;
}
}
Review
-
What 实现更有效工作计划的3个步骤
-
How
- 1.围绕项目目标制定工作计划。
- 2.衡量你需要的学习东西,不要太多也不要太少,适当就好。
- 3.实践资源管理。
Tip
- 1.屏蔽外部依赖,替换原有的 Bean。
- 2.配置加密