复杂链表的复制
题目
请实现函数ComplexListNode Clone(ComplexListNode pHead),复制一个复杂链表。在复杂链表中,每个结点除了有一个m_pNext指针指向下一个点外,还有一个m_pSibling 指向链表中的任意结点或者nullptr。
思路
思路1:先复制结点,用next链接,最后根据原始结点的sibling指针确定该sibling结点距离头结点的位置,从而对复制结点设置sibling指针。但是该思路对于n个结点的链表,每个结点的sibling都需要O(n)个时间步才能找到,所以时间复杂度为O(n^2)
思路2:复制原始结点N创建N’,用next链接。将<N,N’>的配对信息存放入一个哈希表中;在设置sibling时,通过哈希表,只需要用O(1)的时间即可找到复制结点的sibling。该方法的时间复杂度为O(n),但空间复杂度为O(n)。
思路3:复制原始结点N创建N’,将N’链接到N的后面;根据原始结点N的sibling可以快速设置N’结点的sibling,最后将这个长链表拆分成原始链表和复制链表(根据奇偶位置)
测试用例
- 功能测试(sibling指向自己;链表只有一个节点;sibling指向null或者指向节点)
- 特殊测试(头结点为null)
java代码
1 | /** |
总结
- 有关于拆分函数,需要画图分析,才能厘清思路;
- 复制链表时,在演示节点后面直接插入复制节点,这种方法很方便,有较高的效率。