当前位置:网站首页>NowCoderTOP23-27 Binary tree traversal - continuous update ing
NowCoderTOP23-27 Binary tree traversal - continuous update ing
2022-07-31 09:48:00 【Wang Hee Hee-】
TOP23. 二叉树的前序遍历
public class Solution {
/** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * @param root TreeNode类 * @return int整型一维数组 */
public void preorder(List<Integer> list, TreeNode root) {
// 空节点就返回
if(root == null) return;
// 前序遍历 ——> 根 左 右
list.add(root.val);
preorder(list, root.left);
preorder(list, root.right);
}
public int[] preorderTraversal (TreeNode root) {
// The final result is an array,so先定义一个数组
List<Integer> list = new ArrayList();
preorder(list, root);
// 定义一个数组长度为list大小
int[] res = new int[list.size()];
for(int i = 0; i < list.size(); i++) {
res[i] = list.get(i);
}
return res;
}
}
TOP24. 二叉树的中序遍历
public class Solution {
/** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * @param root TreeNode类 * @return int整型一维数组 */
public void inorder(List<Integer> list, TreeNode root) {
// 先判断树是否为空
if(root == null) return;
// 中序遍历 ——> 左 根 右
inorder(list, root.left);
list.add(root.val);
inorder(list, root.right);
}
public int[] inorderTraversal (TreeNode root) {
List<Integer> list = new ArrayList();
inorder(list, root);
// Define an array to store the results of in-order traversal
int[] res = new int[list.size()];
for(int i = 0; i < list.size(); i++) {
res[i] = list.get(i);
}
return res;
}
}
TOP25. 二叉树的后序遍历
public class Solution {
/** * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可 * @param root TreeNode类 * @return int整型一维数组 */
public void postorder(List<Integer> list, TreeNode root) {
if(root == null) return;
postorder(list, root.left);
postorder(list, root.right);
list.add(root.val);
}
public int[] postorderTraversal (TreeNode root) {
List<Integer> list = new ArrayList();
postorder(list, root);
int[] res = new int[list.size()];
for(int i = 0; i < list.size(); i++) {
res[i] = list.get(i);
}
return res;
}
}
TOP26. 求二叉树的层序遍历
public class Solution {
/** * 使用队列实现层序遍历 * @param root TreeNode类 * @return int整型ArrayList<ArrayList<>> */
public ArrayList<ArrayList<Integer>> levelOrder (TreeNode root) {
ArrayList<ArrayList<Integer>> res = new ArrayList<ArrayList<Integer>> ();
if(root == null) return res;
// 队列存储,进行层次遍历
Queue<TreeNode> queue = new LinkedList<TreeNode>();
// 根节点先入队
queue.offer(root);
// 当队列不为空时
while(!queue.isEmpty()){
// 记录二叉树的某一行
ArrayList<Integer> row = new ArrayList<Integer>();
// The size of the queue is the number of elements in this layer
int n = queue.size();
// Start traversing all elements of this layer
for(int i = 0; i < n; i++) {
TreeNode cur = queue.poll();
row.add(cur.val);
//若是左右孩子存在,则存入左右孩子作为下一个层次
if(cur.left != null) queue.add(cur.left);
if(cur.right != null) queue.add(cur.right);
}
// Bring all nodes of a layer into the total result set
res.add(row);
}
return res;
}
}
TOP27. 按之字形顺序打印二叉树
public class Solution {
public ArrayList<ArrayList<Integer> > Print(TreeNode pRoot) {
ArrayList<ArrayList<Integer>> res = new ArrayList<ArrayList<Integer>> ();
if(pRoot == null) return res;
// 队列存储,进行层次遍历
Queue<TreeNode> queue = new LinkedList<TreeNode>();
// 根节点先入队
queue.offer(pRoot);
// 标记位,行数为偶数,逆置
Boolean flag = true;
// 当队列不为空时
while(!queue.isEmpty()){
flag = !flag;
// 记录二叉树的某一行
ArrayList<Integer> row = new ArrayList<Integer>();
// The size of the queue is the number of elements in this layer
int n = queue.size();
// Start traversing all elements of this layer
for(int i = 0; i < n; i++) {
TreeNode cur = queue.poll();
row.add(cur.val);
//若是左右孩子存在,则存入左右孩子作为下一个层次
if(cur.left != null) queue.add(cur.left);
if(cur.right != null) queue.add(cur.right);
}
if (flag)
{
Collections.reverse(row);
}
// Bring all nodes of a layer into the total result set
res.add(row);
}
return res;
}
}
边栏推荐
- The big-eyed Google Chrome has also betrayed, teach you a trick to quickly clear its own ads
- 来n遍剑指--09. 用两个栈实现队列
- 【机器学习】用特征量重要度(feature importance)解释模型靠谱么?怎么才能算出更靠谱的重要度?
- matlab常用符号用法总结
- qt pass custom structure parameters in different threads
- 文件的逻辑结构与物理结构的对比与区别
- loadrunner-controller-手动场景Schedule配置
- MySQL 视图(详解)
- Chapter Six
- 湖仓一体电商项目(二):项目使用技术及版本和基础环境准备
猜你喜欢
随机推荐
js部门预算和支出雷达图
OpenGL es 初识
js implements the 2020 New Year's Day countdown bulletin board
Come n times - 09. Implement queues with two stacks
Kotlin—基本语法(二)
文件管理:目录管理
NowCoderTOP17-22 二分查找/排序——持续更新ing
loadrunner-Controller负载测试-各模块功能记录01测试场景设计
数字加分隔符
OpenGL es 导读篇
零代码工具推荐 八爪鱼采集器
一些计时软件,生产力工具
富文本编辑器Tinymce
js department budget and expenditure radar chart
js空气质量aqi雷达图分析
P5231 [JSOI2012]玄武密码(SAM 经典运用)
djangoWeb应用框架+MySQL数据4
第五章
VMware下安装win10
Mysql+Navicat for Mysql