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

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

相关文章

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

基于Spring实现自定义错误信息返回详解

《基于Spring实现自定义错误信息返回详解》这篇文章主要为大家详细介绍了如何基于Spring实现自定义错误信息返回效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录背景目标实现产出背景Spring 提供了 @RestConChina编程trollerAdvice 用来实现 HTT

如何通过Golang的container/list实现LRU缓存算法

《如何通过Golang的container/list实现LRU缓存算法》文章介绍了Go语言中container/list包实现的双向链表,并探讨了如何使用链表实现LRU缓存,LRU缓存通过维护一个双向... 目录力扣:146. LRU 缓存主要结构 List 和 Element常用方法1. 初始化链表2.

springMVC返回Http响应的实现

《springMVC返回Http响应的实现》本文主要介绍了在SpringBoot中使用@Controller、@ResponseBody和@RestController注解进行HTTP响应返回的方法,... 目录一、返回页面二、@Controller和@ResponseBody与RestController

golang字符串匹配算法解读

《golang字符串匹配算法解读》文章介绍了字符串匹配算法的原理,特别是Knuth-Morris-Pratt(KMP)算法,该算法通过构建模式串的前缀表来减少匹配时的不必要的字符比较,从而提高效率,在... 目录简介KMP实现代码总结简介字符串匹配算法主要用于在一个较长的文本串中查找一个较短的字符串(称为

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1