iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++中怎么利用LeetCode移除有序链表中的重复项
  • 234
分享到

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

2023-06-20 16:06:39 234人浏览 泡泡鱼
摘要

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

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

[LeetCode] 83. Remove Duplicates from Sorted List 移除有序链表中的重复项

Given a sorted linked list, delete all duplicates such that each element appear only once.

Example 1:

Input: 1->1->2
Output: 1->2

Example 2:

Input: 1->1->2->3->3
Output: 1->2->3

这道题让我们移除给定有序链表的重复项,那么可以遍历这个链表,每个结点和其后面的结点比较,如果结点值相同了,只要将前面结点的 next 指针跳过紧挨着的相同值的结点,指向后面一个结点。这样遍历下来,所有重复的结点都会被跳过,留下的链表就是没有重复项的了,代码如下:

解法一:

class Solution {public:    Listnode* deleteDuplicates(ListNode* head) {        ListNode *cur = head;        while (cur && cur->next) {            if (cur->val == cur->next->val) {                cur->next = cur->next->next;            } else {                cur = cur->next;            }        }        return head;    }};

我们也可以使用递归的方法来做,首先判断是否至少有两个结点,若不是的话,直接返回 head。否则对 head->next 调用递归函数,并赋值给 head->next。这里可能比较晕,先看后面一句,返回的时候,head 结点先跟其身后的结点进行比较,如果值相同,那么返回后面的一个结点,当前的 head 结点就被跳过了,而如果不同的话,还是返回 head 结点。可以发现了,进行实质上的删除操作是在最后一句进行了,再来看第二句,对 head 后面的结点调用递归函数,那么就应该 suppose 返回来的链表就已经没有重复项了,此时接到 head 结点后面,在第三句的时候再来检查一下 head 是否又 duplicate 了,实际上递归一直走到了末尾结点,再不断的回溯回来,进行删除重复结点,参见代码如下:

解法二:

class Solution {public:    ListNode* deleteDuplicates(ListNode* head) {        if (!head || !head->next) return head;        head->next = deleteDuplicates(head->next);        return (head->val == head->next->val) ? head->next : head;    }};

看完上述内容,你们掌握C++中怎么利用LeetCode移除有序链表中的重复项的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网其他教程频道,感谢各位的阅读!

--结束END--

本文标题: C++中怎么利用LeetCode移除有序链表中的重复项

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

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

本篇文章演示代码以及资料文档资料下载

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

下载Word文档
猜你喜欢
  • 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++怎么移除有序链表中的重复项
    本文小编为大家详细介绍“C++怎么移除有序链表中的重复项”,内容详细,步骤清晰,细节处理妥当,希望这篇“C++怎么移除有序链表中的重复项”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。Remove Duplicat...
    99+
    2023-06-19
  • C++实现LeetCode(82.移除有序链表中的重复项之二)
    [LeetCode] 82. Remove Duplicates from Sorted List II 移除有序链表中的重复项之二 Given a sorted linked li...
    99+
    2024-04-02
  • C++中怎么利用LeetCode移除链表元素
    今天就跟大家聊聊有关C++中怎么利用LeetCode移除链表元素,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。[LeetCode] 203.Remove Linked List El...
    99+
    2023-06-20
  • 怎么从无序链表中移除重复项
    本篇内容主要讲解“怎么从无序链表中移除重复项”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么从无序链表中移除重复项”吧!顺序删除通过双重循环直接在链表上执行删...
    99+
    2024-04-02
  • C++中怎么利用LeetCode删除链表的节点
    这期内容当中小编将会给大家带来有关C++中怎么利用LeetCode删除链表的节点,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。[LeetCode] 237.Delete Node in a Linked ...
    99+
    2023-06-20
  • C++中怎么利用LeetCode移除元素
    这篇文章给大家介绍C++中怎么利用LeetCode移除元素,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。[LeetCode] 27. Remove Element 移除元素Given an array num...
    99+
    2023-06-20
  • C++实现LeetCode(26.有序数组中去除重复项)
    [LeetCode] 26. Remove Duplicates from Sorted Array 有序数组中去除重复项 Given a sorted array num...
    99+
    2024-04-02
  • LeetCode中怎样删除排序数组中的重复项
    本篇文章给大家分享的是有关LeetCode中怎样删除排序数组中的重复项,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。 1class Solution { 2...
    99+
    2023-06-19
  • C++实现LeetCode(80.有序数组中去除重复项之二)
    [LeetCode] 80. Remove Duplicates from Sorted Array II 有序数组中去除重复项之二 Given a sorted array...
    99+
    2024-04-02
  • C++中怎么利用LeetCode拷贝带有随机指针的链表
    这篇文章将为大家详细讲解有关C++中怎么利用LeetCode拷贝带有随机指针的链表,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。[LeetCode] 138. Copy List with ...
    99+
    2023-06-20
  • JavaScript怎么删除有序数组中的重复项
    本文小编为大家详细介绍“JavaScript怎么删除有序数组中的重复项”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript怎么删除有序数组中的重复项”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。如...
    99+
    2023-06-29
  • Java怎么删除链表中重复的结点
    本篇内容主要讲解“Java怎么删除链表中重复的结点”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Java怎么删除链表中重复的结点”吧!核心考点:链表操作,临界条件检查,特殊情况处理在一个排序的链...
    99+
    2023-06-25
  • JavaScript删除有序数组中的重复项
    如果有一个有序数组 nums ,要求原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。 不要使用额外的数组空间,必须在 原地 修改输入数组 并在使用 O(...
    99+
    2024-04-02
  • C#中怎么删除数组重复项
    今天就跟大家聊聊有关C#中怎么删除数组重复项,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。C#删除数组重复项使用C#查找数据中重复数据,C#删除数组重复项的解决方法。个人感觉,如果在...
    99+
    2023-06-17
  • Python中怎么删除排序数组的重复项
    这期内容当中小编将会给大家带来有关Python中怎么删除排序数组的重复项,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。问题描述:给定一个排序数组,你需要在 原地 删除重复出现的元素,使得每个元素只出现一次...
    99+
    2023-06-16
  • C++中怎么利用LeetCode实现两数相除
    这篇文章将为大家详细讲解有关C++中怎么利用LeetCode实现两数相除,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。[LeetCode] 29. Divide Two Integers 两...
    99+
    2023-06-20
  • C语言 详解如何删除有序数组中的重复项
    目录删除有序数组中的重复项Ⅰa.思路b.图解c.代码d.思考删除有序数组中的重复项Ⅱa.思路b.图解c.代码d.思考删除有序数组中的重复项Ⅰ a.思路 ⭐定义变量 int des...
    99+
    2024-04-02
  • php怎么移除数组中重复的值
    可以使用 PHP 的 array_unique() 函数来移除数组中的重复值。具体示例如下:```php```输出结果为:```Ar...
    99+
    2023-10-12
    php
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作