当前位置: 首页 > news >正文

【LeetCode】填充每个节点的下一个右侧节点指针 II

目录

  • 一、题目
  • 二、解法
  • 完整代码


一、题目

给定一个二叉树:

struct Node {
int val;
Node *left;
Node *right;
Node *next;
}
填充它的每个 next 指针,让这个指针指向其下一个右侧节点。如果找不到下一个右侧节点,则将 next 指针设置为 NULL 。

初始状态下,所有 next 指针都被设置为 NULL 。

示例 1:
在这里插入图片描述

输入:root = [1,2,3,4,5,null,7]
输出:[1,#,2,3,#,4,5,7,#]
解释:给定二叉树如图 A 所示,你的函数应该填充它的每个 next 指针,以指向其下一个右侧节点,如图 B 所示。序列化输出按层序遍历顺序(由 next 指针连接),‘#’ 表示每层的末尾。
示例 2:

输入:root = []
输出:[]

提示:

树中的节点数在范围 [0, 6000] 内
-100 <= Node.val <= 100
进阶:

你只能使用常量级额外空间。
使用递归解题也符合要求,本题中递归程序的隐式栈空间不计入额外空间复杂度。


二、解法

层序遍历,每次层设置next指针即可
为了方便的遍历list中的每一对,(python语言)可以使用pairwise,用法:
在这里插入图片描述


完整代码

"""
# Definition for a Node.
class Node:def __init__(self, val: int = 0, left: 'Node' = None, right: 'Node' = None, next: 'Node' = None):self.val = valself.left = leftself.right = rightself.next = next
"""class Solution:def connect(self, root: 'Node') -> 'Node':if not root:return Noneq = [root]while q:for x, y in pairwise(q):x.next = ytmp = qq = []for node in tmp:if node.left: q.append(node.left)if node.right: q.append(node.right)return root

http://www.lryc.cn/news/404214.html

相关文章:

  • mac无法清空废纸篓怎么办 mac废纸篓清空了如何找回 cleanmymac误删文件怎么恢复
  • 树上启发加点分治思想
  • 【iOS】类对象的结构分析
  • 接口性能优化思路
  • PyQt5 多线程编程详细教程
  • uniapp小程序上传pdf文件
  • Python酷库之旅-第三方库Pandas(036)
  • Python爬虫(2) --爬取网页页面
  • 【iOS】——探究isKindOfClass和isMemberOfClass底层实现
  • Python 热门面试题(七)
  • STM32项目分享:智能宠物喂食系统
  • 数据结构——栈的实现(java实现)与相应的oj题
  • linux修改时区为CST
  • 【Spring Security】初识Spring Security
  • 配置单区域OSPF
  • SQL中的游标是什么?
  • 7. LangChain4j如何使用统一api调用?
  • RPM、YUM 安装 xtrabackup 8 (mysql 热备系列一)包含rpm安装 mysql 8 配置主从
  • maven项目打成可运行的jar及pom中的依赖一同打包
  • Gettler‘s Screep World 笔记 Ⅰ
  • 联合体(union)的定义以及如何与结构体(struct)不同
  • 【Spark官方文档部分翻译】RDD编程指南(RDD Programming Guide)
  • 前端八股文 $set
  • Connecting weaviate with langflow across docker containers
  • 【linux vim使用说明】
  • cocos2d-x安装和项目
  • 因果推断 | 双重机器学习(DML)算法原理和实例应用
  • Flutter 开源库学习
  • 自主巡航,目标射击
  • MySQL中EXPLAIN关键字详解