千家信息网

Java复杂链表的复制方法是什么

发表于:2025-02-03 作者:千家信息网编辑
千家信息网最后更新 2025年02月03日,今天小编给大家分享一下Java复杂链表的复制方法是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一
千家信息网最后更新 2025年02月03日Java复杂链表的复制方法是什么

今天小编给大家分享一下Java复杂链表的复制方法是什么的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。

复杂链表的概念:

在复杂链表中,每个结点除了有一个_pnext指针指向下一个结点外,还有一个_pSibling指向链表中的任意结点或者NULL。

复杂链表每个结点的结构如下:

//复杂链表结点的结构

template

struct ComplexListNode

{

ComplexListNode()

:_pnext(NULL)

,_pSibling(NULL)

{ }


ComplexListNode(const T& x)

:_pnext(NULL)

,_pSibling(NULL)

,value(x)

{ }


T value;//数据

ComplexListNode* _pnext;//指向下一个结点

ComplexListNode* _pSibling;//指向任意结点

};

复杂链表的复制:

方法1:

第一步,复制链表的每一个结点,并用_pnext链接起来;第二步,设置链表每一个结点的_pSibling。假设原始链表的某个结点N的_pSibling指向结点S,而S的位置可在N前也可在N后,所以要确定S的位置需要从头结点开始找,若从头开始沿着_pnext经过s步找到S,那么复制链表上的N'结点的_pSibling离复制链表的头结点的距离也是沿着_pnext指针s步。由于定位每个结点的_pSibling都需要从头结点开始经过O(n)步才能找到,所以时间复杂度为O(n^2)。比较浪费时间。

方法2:

第一步,复制链表的每一个结点,并用_pnext链接起来;第二步,设置每个结点的_pSibling。如果在原始链表的结点N的_pSibling指向结点S,那么复制链表时,对应的N'应该指向S'。因为有了哈希表,用O(1)的时间根据S找到S'。这种方法以空间换时间。

方法3:

第一步,对应于每一个结点,创建一个新的结点,并连接在原结点的后边。

参考代码:

//创建每个新的结点pCloned 分别连接到每个原结点的后边

template

void ClonedNodes(ComplexListNode* pHead)

{

ComplexListNode* pNode = pHead;

while (pNode != NULL)

{

ComplexListNode* pCloned = new ComplexListNode(pNode->value);

pCloned->_pnext = pNode->_pnext;

pNode->_pnext = pCloned;

pNode = pCloned->_pnext;

}

}

第二步,设置复制出来结点的_pSibling,假设原始链表的A指向C,那么对应复制出来的A'对应C'。

参考代码:

//设置复制出来每个结点的_pSibling的值

template

void ConnectSiblingNodes(ComplexListNode* pHead)

{

ComplexListNode* pNode = pHead;

while (pNode)

{

ComplexListNode* pCloned = pNode->_pnext;

if(pNode->_pSibling != NULL)

{

pCloned->_pSibling = pNode->_pSibling->_pnext;

}

pNode = pCloned->_pnext;

}

}

第三步,拆分链表,奇数位置的结点用_pnext链接起来构成原始链表,偶数位置的结点用_pnext链接起来构成复制的复杂链表。

参考代码:

//拆分合并的链表,把奇数位置上的结点用_pnext链接起来就是原始链表,把偶数位置上的结点用_pnext链接起来就是复制出来的链表

template

ComplexListNode* ReconnectNodes(ComplexListNode* pHead)

{

ComplexListNode* pNode = pHead;

ComplexListNode* pClonedHead = NULL;

ComplexListNode* pClonedNode = NULL;

if(pNode != NULL)

{

pClonedHead = pClonedNode = pHead->_pnext;

pNode->_pnext = pClonedNode->_pnext;

pNode = pNode->_pnext;

}

while (pNode != NULL)

{

pClonedNode->_pnext = pNode->_pnext;

pClonedNode = pClonedNode->_pnext;

pNode->_pnext = pClonedNode->_pnext;

pNode = pNode->_pnext;

}

return pClonedHead;

}

将以上三步合起来,就是复制的完整过程

//复制复杂链表函数

template

ComplexListNode* Clone(ComplexListNode* pHead)

{

ClonedNodes(pHead);

ConnectSiblingNodes(pHead);

return ReconnectNodes(pHead);

}

测试代码如下:

void test()

{

ComplexListNode List1(1.2);

ComplexListNode List2(1.4);

ComplexListNode List3(2.3);

ComplexListNode List4(3.6);

ComplexListNode List5(4.5);


List1._pnext = &List2;

List2._pnext = &List3;

List3._pnext = &List4;

List4._pnext = &List5;

List1._pSibling = &List3;

List4._pSibling = &List2;

List2._pSibling = &List5;


ComplexListNode* pHead = Clone(&List1);

}

以上就是"Java复杂链表的复制方法是什么"这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注行业资讯频道。

结点 复杂 指向 方法 位置 链接 原始 代码 就是 时间 知识 篇文章 参考 从头 复制方法 偶数 内容 可在 奇数 指针 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 莫氏推动下一代网络技术发展 计算机网络概论和计算机网络安全 服务器 思科模拟器 申请网络安全策略需要哪些信息 上海旭白网络技术有限公司 乡镇网络安全应急机制 老头环为啥无法登录服务器 数据库设计原则思维导图 网络技术适合女生学吗 组态用服务器还是工控机 如何判断网站是什么数据库 专业数据库库存管理 开展网络安全知识广播稿 文明重启怎么卖服务器 软件开发框架什么意思 憨猴互联网科技 什么负责筹备协调网络安全工作 测试开发和软件开发职业发展 湖南浪潮服务器虚拟化优化云主机 平安非金融互联网科技 数据库热点技术 数据库技术应用大纲 NLP软件开发 软件开发的职务有哪些 网站的数据库怎么打开方式 网络安全法直播 后台的服务器怎么连接 军营网络安全周主题 石河子新华互联网科技价格 成都用户管理界面软件开发
0