给定一个二叉树,返回每层上节点的链表,设计算法

2023-11-11 04:18

本文主要是介绍给定一个二叉树,返回每层上节点的链表,设计算法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

思路:

1、链表存储每层节点的数据,这样保证指针后移,进行存储该层的节点。

2、遍历上层的节点,通过队列的pull跟add,遍历该层的节点后pull出,同时添加上下个循环要遍历的节点(下层的父节点)。

具体代码如下:

import java.util.*;public class ListTreeNodeDepth {/*** 时间复杂度 o(n) 空间复杂度o(n)* @param args*/public static void main(String[] args) {TreeNode root = new TreeNode(1);TreeNode left1 = new TreeNode(2);TreeNode right1 = new TreeNode(3);TreeNode left2 = new TreeNode(4);TreeNode left3 = new TreeNode(5);TreeNode right2 = new TreeNode(7);TreeNode left4 = new TreeNode(8);root.left = left1;root.right = right1;left1.left = left2;left1.right = left3;right1.right = right2;left2.left = left4;ListNode[] list = listOfDepth(root);for (ListNode node:list) {List<Integer> l = new ArrayList<Integer>();l.add(node.value);while (node.next!=null) {l.add(node.next.value);node.next = node.next.next;}System.out.println(Arrays.toString(l.toArray()));}}/*** 节点*/static class TreeNode {int value;TreeNode left;TreeNode right;TreeNode(int v) {value = v;}}/*** 链表,存储每层的节点*/static class ListNode {int value;ListNode next;ListNode(int v) {value = v;}}/*** 利用队列的pull跟add,推拉来控制每层遍历的节点,并添加到每层的链表中*/public static ListNode[] listOfDepth(TreeNode root) {if (root == null) {return null;}//BFS中的队列Queue<TreeNode> queue = new LinkedList<>();//先把根节点入队,然后执行“弹一个,加n个”queue.add(root);//存放每个链表第一个有实际值(非哑元)节点的容器,ArrayList实际上是一个可变长的数组List<ListNode> list = new ArrayList<>();//只要队列中还有元素就要不停的出队,直到队列中的所有元素都已出队while (!queue.isEmpty()) {//当前队列的长度,即当前层元素的总个数int size = queue.size();//链表的头结点,不放实际的值(哑元)ListNode head = new ListNode(0);//链表移动指针,让它始终指向当表链表的最后一个元素ListNode p = head;//将当前层的节点逐个出队,把出队节点的子节点入队for (int i = 0; i < size; i++) {TreeNode poll = queue.poll();//链表元素追加p.next = new ListNode(poll.value);//指针向后移动一个元素,使p指向链表末尾p = p.next;if (poll.left != null) {//当前出队的节点有左孩子,则左孩子入队queue.add(poll.left);}if (poll.right != null) {//当前出队的节点有右孩子,则右孩子入队queue.add(poll.right);}}//for循环走完后就遍历完了一层,将存储该层节点的链表第一个有实际值的节点入队list.add(head.next);}//将可变长的数组转化成定长数组(因为函数的返回值要求了返回一个定长数组ListNode[])return list.toArray(new ListNode[list.size()]);}}

参考:https://leetcode-cn.com/problems/list-of-depth-lcci/

https://blog.csdn.net/qq_43988642/article/details/108098431

这篇关于给定一个二叉树,返回每层上节点的链表,设计算法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/387483

相关文章

统一返回JsonResult踩坑的记录

《统一返回JsonResult踩坑的记录》:本文主要介绍统一返回JsonResult踩坑的记录,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录统一返回jsonResult踩坑定义了一个统一返回类在使用时,JsonResult没有get/set方法时响应总结统一返回

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

MyBatis设计SQL返回布尔值(Boolean)的常见方法

《MyBatis设计SQL返回布尔值(Boolean)的常见方法》这篇文章主要为大家详细介绍了MyBatis设计SQL返回布尔值(Boolean)的几种常见方法,文中的示例代码讲解详细,感兴趣的小伙伴... 目录方案一:使用COUNT查询存在性(推荐)方案二:条件表达式直接返回布尔方案三:存在性检查(EXI

Python函数返回多个值的多种方法小结

《Python函数返回多个值的多种方法小结》在Python中,函数通常用于封装一段代码,使其可以重复调用,有时,我们希望一个函数能够返回多个值,Python提供了几种不同的方法来实现这一点,需要的朋友... 目录一、使用元组(Tuple):二、使用列表(list)三、使用字典(Dictionary)四、 使

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ

Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案

《Vue3组件中getCurrentInstance()获取App实例,但是返回null的解决方案》:本文主要介绍Vue3组件中getCurrentInstance()获取App实例,但是返回nu... 目录vue3组件中getCurrentInstajavascriptnce()获取App实例,但是返回n

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

Python获取C++中返回的char*字段的两种思路

《Python获取C++中返回的char*字段的两种思路》有时候需要获取C++函数中返回来的不定长的char*字符串,本文小编为大家找到了两种解决问题的思路,感兴趣的小伙伴可以跟随小编一起学习一下... 有时候需要获取C++函数中返回来的不定长的char*字符串,目前我找到两种解决问题的思路,具体实现如下: