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

总结:

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

相关推荐
无敌最俊朗@28 分钟前
友元的作用与边界
算法
谅望者31 分钟前
数据分析笔记03:概率分布理论
笔记·数据分析·概率论
Miraitowa_cheems42 分钟前
LeetCode算法日记 - Day 104: 通配符匹配
linux·数据结构·算法·leetcode·深度优先·动态规划
程序员东岸1 小时前
从零开始学二叉树(上):树的初识 —— 从文件系统到树的基本概念
数据结构·经验分享·笔记·学习·算法
谅望者1 小时前
数据分析笔记09:Python条件语循环
笔记·python·数据分析
全栈游侠1 小时前
Cortex-M3 02-地址映射
笔记
甄心爱学习2 小时前
数据挖掘11-分类的高级方法
人工智能·算法·分类·数据挖掘
菩提树下的凡夫2 小时前
Node.js+Vue的学习笔记
笔记·学习·node.js
蒙奇D索大2 小时前
【计算机网络】考研408 | 数据链路层的“安全卫士”:探秘检错编码之奇偶校验码
经验分享·笔记·计算机网络·考研·改行学it
雾岛听风眠2 小时前
光耦学习笔记
笔记·学习