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

【Leetcode】430. 扁平化多级双向链表

目录

  • 一、题目
  • 二、思路
    • 2.1 解题思路
    • 2.2 代码尝试
    • 2.3 疑难问题
    • 2.4 AI复盘
  • 三、解法
  • 四、收获
    • 4.1 心得
    • 4.2 举一反三

一、题目


在这里插入图片描述

二、思路


2.1 解题思路

2.2 代码尝试

/*
// Definition for a Node.
class Node {
public:
    int val;
    Node* prev;
    Node* next;
    Node* child;
};
*/

class Solution {
public:
    Node* flatten(Node* head) {
        //先递归找到最下面的子节点

        Node* p=head;
        p=child(p->child);

    }

    Node* child(Node* head){
        if(head->child){
            head=child(head->child);
            return head;
        }else{
            return head;
        }
        
    }

    Node* nex(Node* head){
        
    }
};

2.3 疑难问题

2.4 AI复盘

三、解法


class Solution {
public:
    Node* flatten(Node* head) {
        function<Node*(Node*)> dfs = [&](Node* node) {
            Node* cur = node;
            // 记录链表的最后一个节点
            Node* last = nullptr;

            while (cur) {
                Node* next = cur->next;
                //  如果有子节点,那么首先处理子节点
                if (cur->child) {
                    Node* child_last = dfs(cur->child);

                    next = cur->next;
                    //  将 node 与 child 相连
                    cur->next = cur->child;
                    cur->child->prev = cur;

                    //  如果 next 不为空,就将 last 与 next 相连
                    if (next) {
                        child_last->next = next;
                        next->prev = child_last;
                    }

                    // 将 child 置为空
                    cur->child = nullptr;
                    last = child_last;
                }
                else {
                    last = cur;
                }
                cur = next;
            }
            return last;
        };

        dfs(head);
        return head;
    }
};

作者:力扣官方题解
链接:https://leetcode.cn/problems/flatten-a-multilevel-doubly-linked-list/solutions/1013884/bian-ping-hua-duo-ji-shuang-xiang-lian-b-383h/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

四、收获


4.1 心得

需要找一个简单的题实现一下递归

4.2 举一反三


http://www.kler.cn/a/599057.html

相关文章:

  • SFT和RLHF是什么意思?
  • React + Node.js实践 仿B站评论
  • 邀请媒体参加线下活动
  • 基于DeepSeek的智能体搭建
  • HAL库中断的理解
  • 个人博客系统 --- 测试报告
  • linux--时区查看和修改
  • 深度学习2-线性回归表示
  • Elasticsearch 中的数据分片问题
  • Linux中查找标准库函数的定义
  • 【容器运维】docker搭建私有仓库
  • SpringBoot分布式定时任务实战:告别重复执行的烦恼
  • 蓝桥杯_DS1302时钟
  • 游戏引擎学习第174天
  • 【C++复习】——类型转换
  • git,openpnp - 根据安装程序打包名称找到对应的源码版本
  • LeetCode 3038 相同分数的最大操作数目I
  • 基于单片机的农作物自动灌溉系统
  • 蓝桥杯第九天 2022 省赛 第 4 题 最少刷题数
  • nt!KeWaitForMultipleObjects函数分析之一个例子ExpWorkerThreadBalanceManager