返回顶部
首页 > 资讯 > 前端开发 > JavaScript >怎么从无序链表中移除重复项
  • 943
分享到

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

2024-04-02 19:04:59 943人浏览 薄情痞子
摘要

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

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

顺序删除

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

假设外层循环从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,继续遍历其余结点。

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

--结束END--

本文标题: 怎么从无序链表中移除重复项

本文链接: https://lsjlt.com/news/83944.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 怎么从无序链表中移除重复项
    本篇内容主要讲解“怎么从无序链表中移除重复项”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么从无序链表中移除重复项”吧!顺序删除通过双重循环直接在链表上执行删...
    99+
    2024-04-02
  • C++怎么移除有序链表中的重复项
    本文小编为大家详细介绍“C++怎么移除有序链表中的重复项”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++怎么移除有序链表中的重复项”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。Remove Duplicat...
    99+
    2023-06-19
  • C++中怎么利用LeetCode移除有序链表中的重复项
    C++中怎么利用LeetCode移除有序链表中的重复项,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。[LeetCode] 83. Remove Duplicates from ...
    99+
    2023-06-20
  • C++实现LeetCode(83.移除有序链表中的重复项)
    [LeetCode] 83. Remove Duplicates from Sorted List 移除有序链表中的重复项 Given a sorted linked list, d...
    99+
    2024-04-02
  • C++实现LeetCode(82.移除有序链表中的重复项之二)
    [LeetCode] 82. Remove Duplicates from Sorted List II 移除有序链表中的重复项之二 Given a sorted linked li...
    99+
    2024-04-02
  • Java怎么删除链表中重复的结点
    本篇内容主要讲解“Java怎么删除链表中重复的结点”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java怎么删除链表中重复的结点”吧!核心考点:链表操作,临界条件检查,特殊情况处理在一个排序的链...
    99+
    2023-06-25
  • Python中怎么删除排序数组的重复项
    这期内容当中小编将会给大家带来有关Python中怎么删除排序数组的重复项,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。问题描述:给定一个排序数组,你需要在 原地 删除重复出现的元素,使得每个元素只出现一次...
    99+
    2023-06-16
  • JavaScript怎么删除有序数组中的重复项
    本文小编为大家详细介绍“JavaScript怎么删除有序数组中的重复项”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript怎么删除有序数组中的重复项”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。如...
    99+
    2023-06-29
  • sql如何删除表中重复项
    要删除表中的重复项,可以使用以下SQL语句: DELETE FROM table_name WHERE rowid ...
    99+
    2024-04-09
    sql
  • C++中怎么利用LeetCode移除链表元素
    今天就跟大家聊聊有关C++中怎么利用LeetCode移除链表元素,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。[LeetCode] 203.Remove Linked List El...
    99+
    2023-06-20
  • C语言怎么移除链表元素
    这篇“C语言怎么移除链表元素”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C语言怎么移除链表元素”文章吧。1、移除链表元素链...
    99+
    2023-06-29
  • Python中移除List重复项的五种方法
     本文列些处几种去除在Python 列表中(list)可能存在的重复项,这在很多应用程序中都会遇到的需求,作为程序员最好了解其中的几种方法 以备在用到时能够写出有效的程序。 方法1:朴素方法 这种方式是在...
    99+
    2022-06-02
    Python 移除List重复项 Python 移除重复项
  • 删除排序数组中的重复项
    给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成。示例 1:给定数组 nums = [1,1,2],&...
    99+
    2023-06-02
  • Python中字典列表中删除重复项
    要从字典列表中删除重复项: 使用字典推导来遍历列表。使用每个 id 属性的值作为键,使用字典作为值。使用 dict.values() 方法只获取唯一的字典。使用&...
    99+
    2023-05-16
    Python字典删除重复项 Python 删除重复项 Python列表删除重复项
  • php怎么移除数组中重复的值
    可以使用 PHP 的 array_unique() 函数来移除数组中的重复值。具体示例如下:```php```输出结果为:```Ar...
    99+
    2023-10-12
    php
  • python如何移除列表中的重复元素
    这篇文章主要介绍了python如何移除列表中的重复元素,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。移除列表中的重复元素感谢你能够认真阅读完...
    99+
    2024-04-02
  • LeetCode中怎样删除排序数组中的重复项
    本篇文章给大家分享的是有关LeetCode中怎样删除排序数组中的重复项,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 1class Solution { 2...
    99+
    2023-06-19
  • C#中怎么删除数组重复项
    今天就跟大家聊聊有关C#中怎么删除数组重复项,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。C#删除数组重复项使用C#查找数据中重复数据,C#删除数组重复项的解决方法。个人感觉,如果在...
    99+
    2023-06-17
  • JavaScript删除有序数组中的重复项
    如果有一个有序数组 nums ,要求原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。 不要使用额外的数组空间,必须在 原地 修改输入数组 并在使用 O(...
    99+
    2024-04-02
  • 如何从MySQL表中删除以相反顺序存储的重复值?
    为了理解这个概念,我们使用表‘Details_city’中的数据,如下 -mysql> Select * from details_city; +--------+--------+ | City1 | City2 | ...
    99+
    2023-10-22
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作