加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

如何在C中的O(1)时间内合并两个链表?

发布时间:2020-12-16 10:42:39 所属栏目:百科 来源:网络整理
导读:给定两个列表l1,l2,显示如何在O(1)时间内合并它们.列表的数据结构取决于您的设计方式.通过合并,我的意思是说列表的联合. 例如:List1 = {1,2,3} List2 = {2,4,5} 合并清单= {1,3,5} 解决方法 您正在寻找的不是在O(1)时间内合并两个“列表”的算法.如果您将“
给定两个列表l1,l2,显示如何在O(1)时间内合并它们.列表的数据结构取决于您的设计方式.通过合并,我的意思是说列表的联合.

例如:List1 = {1,2,3}
List2 = {2,4,5}

合并清单= {1,3,5}

解决方法

您正在寻找的不是在O(1)时间内合并两个“列表”的算法.如果您将“列表”视为“链接列表”,那么这不能比O(n)更快地完成.

您要求查找的是用于存储此数据的数据结构,该数据结构支持在O(1)时间内合并.此数据结构不是列表.在“硬”O(1)时间内合并仍然是不可能的,但是有一些数据结构支持在摊销的O(1)时间内合并.也许最着名的例子是Fibonacci Heap.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读