我的编程空间,编程开发者的网络收藏夹
学习永远不晚

怎么从无序链表中移除重复项

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

怎么从无序链表中移除重复项

本篇内容主要讲解“怎么从无序链表中移除重复项”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么从无序链表中移除重复项”吧!

顺序删除

通过双重循环直接在链表上执行删除操作。外层循环用一个指针从第一个结点开始遍历整个链表,然后内层循环用另外一个指针遍历其余结点,将与外层循环遍历到的指针所指结点的数据域相同的结点删除,如下图所示。

假设外层循环从outerCur开始遍历,当内层循环指针innerCur遍历到上图实线所示的位置(outerCur.data==innerCur.data)时,此时需要把innerCur指向的结点删除。

具体步骤如下:

  • 用tmp记录待删除的结点的地址。

  • 为了能够在删除tmp结点后继续遍历链表中其余的结点,使innerCur指针指向它的后继结点:innerCur=innerCur.next。

  • 从链表中删除tmp结点。

实现代码如下:

怎么从无序链表中移除重复项

怎么从无序链表中移除重复项

怎么从无序链表中移除重复项

运行结果:

怎么从无序链表中移除重复项

算法性能分析

由于这种方法采用双重循环对链表进行遍历,因此,时间复杂度为O(N^2)。其中,N为链表的长度。在遍历链表的过程中,使用了常量个额外的指针变量来保存当前遍历的结点、前驱结点和被删除的结点,因此,空间复杂度为O(1)。

递归法

主要思路为:对于结点cur,首先递归地删除以cur.next为首的子链表中重复的结点,接着从以cur.next为首的子链表中找出与cur有着相同数据域的结点并删除。

实现代码如下:

怎么从无序链表中移除重复项

怎么从无序链表中移除重复项

怎么从无序链表中移除重复项

算法性能分析

这种方法与方法一类似,从本质上而言,由于这种方法需要对链表进行双重遍历,因此,时间复杂度为O(N^2)。其中,N为链表的长度。由于递归法会增加许多额外的函数调用,因此,从理论上讲,该方法效率比前面的方法低。

空间换时间

通常情况下,为了降低时间复杂度,往往在条件允许的情况下,通过使用辅助空间实现。

具体而言,主要思路如下。

  • 建立一个HashSet,HashSet中的内容为已经遍历过的结点内容,并将其初始化为空。

  • 从头开始遍历链表中的所以结点,存在以下两种可能性:

    • 如果结点内容已经在HashSet中,则删除此结点,继续向后遍历。

    • 如果结点内容不在HashSet中,则保留此结点,将此结点内容添加到HashSet中,继续向后遍历。

「引申:如何从有序链表中移除重复项?」

如链表:1,3、5、5、7、7、8、9

去重后:1,3、5、7、8、9

分析与解答

上述介绍的方法也适用于链表有序的情况,但是由于以上方法没有充分利用到链表有序这个条件,因此,算法的性能肯定不是最优的。本题中,由于链表具有有序性,因此,不需要对链表进行两次遍历。所以,有如下思路:用cur  指向链表第一个结点,此时需要分为以下两种情况讨论。

  • 如果cur.data==cur.next.data,那么删除cur.next结点。

  • 如果cur.data!=cur.next.data,那么cur=cur.next,继续遍历其余结点。

到此,相信大家对“怎么从无序链表中移除重复项”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

怎么从无序链表中移除重复项

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

C++怎么移除有序链表中的重复项

本文小编为大家详细介绍“C++怎么移除有序链表中的重复项”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++怎么移除有序链表中的重复项”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。Remove Duplicat
2023-06-19

C++中怎么利用LeetCode移除有序链表中的重复项

C++中怎么利用LeetCode移除有序链表中的重复项,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。[LeetCode] 83. Remove Duplicates from
2023-06-20

Java怎么删除链表中重复的结点

本篇内容主要讲解“Java怎么删除链表中重复的结点”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java怎么删除链表中重复的结点”吧!核心考点:链表操作,临界条件检查,特殊情况处理在一个排序的链
2023-06-25

C++中怎么利用LeetCode移除链表元素

今天就跟大家聊聊有关C++中怎么利用LeetCode移除链表元素,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。[LeetCode] 203.Remove Linked List El
2023-06-20

JavaScript怎么删除有序数组中的重复项

本文小编为大家详细介绍“JavaScript怎么删除有序数组中的重复项”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript怎么删除有序数组中的重复项”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。如
2023-06-29

Python中怎么删除排序数组的重复项

这期内容当中小编将会给大家带来有关Python中怎么删除排序数组的重复项,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。问题描述:给定一个排序数组,你需要在 原地 删除重复出现的元素,使得每个元素只出现一次
2023-06-16

php怎么移除数组中重复的值

可以使用 PHP 的 array_unique() 函数来移除数组中的重复值。具体示例如下:```php$array = array(1, 2, 2, 3, 4, 4, 5);$result = array_unique($array);p
2023-10-12

LeetCode中怎样删除排序数组中的重复项

本篇文章给大家分享的是有关LeetCode中怎样删除排序数组中的重复项,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 1class Solution { 2public: 3
2023-06-19

C#中怎么删除数组重复项

今天就跟大家聊聊有关C#中怎么删除数组重复项,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。C#删除数组重复项使用C#查找数据中重复数据,C#删除数组重复项的解决方法。个人感觉,如果在
2023-06-17

如何从MySQL表中删除以相反顺序存储的重复值?

为了理解这个概念,我们使用表‘Details_city’中的数据,如下 -mysql> Select * from details_city;+--------+--------+| City1 | City2 |+-------
2023-10-22

python怎么删除列表中的重复值

可以使用set()函数来删除列表中的重复值。步骤如下:定义一个列表。将列表转换为集合,即使用set()函数。将集合转换回列表,即使用list()函数。以下是一个例子:my_list = [1, 2, 3, 4, 3, 2, 1]my
2023-10-24

vbscript中怎么从文本文件中删除重复行

本篇文章为大家展示了vbscript中怎么从文本文件中删除重复行,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。首先,假定您有一个文本文件,其中每一行都表示一条单独的记录。这似乎不太可能,但也许您的文
2023-06-08

Python中怎么实现列表去重复项

Python中怎么实现列表去重复项,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。方式## 1. 新建列表,如果新列表中不存在,则添加到新列表。 def unique(dat
2023-06-16

python怎么去除列表中的重复元素

可以使用set()函数将列表转换为集合,再将集合转换为列表,即可去除列表中的重复元素。具体代码如下:```python# 原始列表lst = [1, 2, 3, 4, 2, 3, 1, 5]# 去除重复元素后的列表lst_unique =
2023-09-23

编程热搜

目录