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

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

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

北京

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

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

看不清楚,换张图片

免费获取短信验证码

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

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

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++怎么移除有序链表中的重复项”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网行业资讯频道。

免责声明:

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

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

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

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

下载Word文档

猜你喜欢

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

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

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

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

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

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

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

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

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

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

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

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

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++中怎么利用LeetCode删除链表的节点

这期内容当中小编将会给大家带来有关C++中怎么利用LeetCode删除链表的节点,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。[LeetCode] 237.Delete Node in a Linked
2023-06-20

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

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

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

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

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录