leetcode做题笔记116. 填充每个节点的下一个右侧节点指针

给定一个 完美二叉树,其所有叶子节点都在同一层,每个父节点都有两个子节点。二叉树定义如下:

复制代码
struct Node {
  int val;
  Node *left;
  Node *right;
  Node *next;
}

填充它的每个 next 指针,让这个指针指向其下一个右侧节点。如果找不到下一个右侧节点,则将 next 指针设置为 NULL

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

思路一:递归

cpp 复制代码
struct Node* connect(struct Node* root) {
	if(root==NULL)return NULL;
    else if(root->left == NULL || root->right == NULL) return root;

        root->left->next = root->right;
        struct Node* left = root->left->right;
        struct Node* right = root->right->left;
    while(left!=NULL&& right!=NULL){
        left->next = right;
        left = left->right;
        right = right->left;


    }
    root->left = connect(root->left);
        root->right = connect(root->right);
        return root;
    
}

分析:

本题要将每个next指针指向下一个右侧节点,可想到使用递归将左子树next指针指向right,再将右子树向下递归,最后输出root

总结:

本题考察递归的应用,将二叉树左子树指针指向右子树即可解决

相关推荐
chushiyunen15 小时前
php笔记、下载安装等
开发语言·笔记·php
元直数字电路验证15 小时前
云计算实验笔记(一):IaaS 与虚拟化全景 —— 从 VirtualBox 到云上 EC2 的完整映射
笔记·云计算·perl
Cloud_Shy61815 小时前
解读《Effective Python 3rd Edition》:从练气到老魔(第二章 Item 13 - 16)
c语言·开发语言·网络·笔记·python·编辑器
m沐沐15 小时前
【机器学习】信用卡欺诈检测实战:逻辑回归 + 过采样
人工智能·算法·机器学习·pycharm·逻辑回归
Amarantine、沐风倩✨15 小时前
java -jar 命令-检查隐藏启动日志
笔记
路人蛃15 小时前
【深入理解计算机系统】第一章(计算机系统漫游)笔记
笔记
代码中介商15 小时前
图论入门:从基础到遍历算法
数据结构·算法·图论
小满Autumn15 小时前
WPF 依赖属性速查手册
笔记·c#·wpf·上位机·mvvm
csdn_aspnet15 小时前
Python 霍尔分区算法(Hoare‘s Partition Algorithm)
开发语言·python·算法
8Qi815 小时前
LeetCode 295:数据流的中位数(Median Finder)—— Java 题解 ✅
java·算法·leetcode·优先队列··中位数