您的位置:首页 > 房产 > 建筑 > 全国信用企业信息查询系统_互联网服务平台备案单位机动车_潍坊疫情最新消息_企业宣传ppt

全国信用企业信息查询系统_互联网服务平台备案单位机动车_潍坊疫情最新消息_企业宣传ppt

2024/12/27 7:24:45 来源:https://blog.csdn.net/weixin_44245188/article/details/143663012  浏览:    关键词:全国信用企业信息查询系统_互联网服务平台备案单位机动车_潍坊疫情最新消息_企业宣传ppt
全国信用企业信息查询系统_互联网服务平台备案单位机动车_潍坊疫情最新消息_企业宣传ppt

You are given a doubly linked list, which contains nodes that have a next pointer, a previous pointer, and an additional child pointer. This child pointer may or may not point to a separate doubly linked list, also containing these special nodes. These child lists may have one or more children of their own, and so on, to produce a multilevel data structure as shown in the example below.

Given the head of the first level of the list, flatten the list so that all the nodes appear in a single-level, doubly linked list. Let curr be a node with a child list. The nodes in the child list should appear after curr and before curr.next in the flattened list.

Return the head of the flattened list. The nodes in the list must have all of their child pointers set to null.
你会得到一个双链表,其中包含的节点有一个下一个指针、一个前一个指针和一个额外的 子指针 。这个子指针可能指向一个单独的双向链表,也包含这些特殊的节点。这些子列表可以有一个或多个自己的子列表,以此类推,以生成如下面的示例所示的 多层数据结构 。

给定链表的头节点 head ,将链表 扁平化 ,以便所有节点都出现在单层双链表中。让 curr 是一个带有子列表的节点。子列表中的节点应该出现在扁平化列表中的 curr 之后 和 curr.next 之前 。

返回 扁平列表的 head 。列表中的节点必须将其 所有 子指针设置为 null 。

输入:head = [1,2,3,4,5,6,null,null,null,7,8,9,10,null,null,11,12]
输出:[1,2,3,7,8,11,12,9,10,4,5,6]
在这里插入图片描述解释:输入的多级列表如上图所示。
扁平化后的链表如下图:
在这里插入图片描述遇到一个节点有 child 的

优先把 child 挪到该节点的 next 上面
然后一口气找到这个 child 链的最末尾(不要管这条 child 链中间是否还有其他的节点存在 child 分支,先跳过,后面处理)
把该末尾节点跟前面开的口子接上

完成上面一轮, curr 指针向前挪动一步,继续处理以上三步,这样就能够把题目的意思给模拟出来,扁平化链表。
迭代法

class Solution:def flatten(self, head: 'Node') -> 'Node':curr = headwhile curr:if curr.child:nex = curr.nextchild = curr.child# 遇到一个child,先在 curr 这里豁开一个口子,把child变成 next 的关系curr.next = childcurr.child = Nonechild.prev = curr# 找到当前这个child链的最末尾while child.next:child = child.next# 把child的最末尾的节点,跟上面豁开的口子 nex 接上if nex:nex.prev = childchild.next = nexcurr = curr.nextreturn head

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com