LeetCode中如何删除排序链表中的重复元素
发表于:2025-12-03 作者:千家信息网编辑
千家信息网最后更新 2025年12月03日,本篇文章为大家展示了LeetCode中如何删除排序链表中的重复元素,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、题目描述给定一个排序链表,删除所有重复的元
千家信息网最后更新 2025年12月03日LeetCode中如何删除排序链表中的重复元素
本篇文章为大家展示了LeetCode中如何删除排序链表中的重复元素,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。
一、题目描述
给定一个排序链表,删除所有重复的元素,使得每个元素只出现一次。
示例 1:
输入: 1->1->2 输出: 1->2
示例 2:
输入: 1->1->2->3->3 输出: 1->2->3
二、解题思路
本题考查的是对链表的基础指针操作,只要在遍历链表的同时找到要删除的节点指针,然后删除即可,步骤如下:
对链表的头结点副本 current 进行遍历 循环遍历直到到最后一个节点 每次遍历判断当前节点值是否等于下一节点值 如果相等则删除下一节点 如果不等则继续遍历下一节点 最终返回链表头结点
class Solution {
public:
ListNode* deleteDuplicates(ListNode* head) {
// 0. 空链表返回 nullptr
if (head == nullptr)
return nullptr;
// 1. 不对头指针操作,头指针用于返回结果
ListNode *cur = head;
ListNode *del_node = nullptr;
while (current->next != nullptr) {
// 2. 找到元素相同的节点
if (cur->val == cur->next->val) {
// 3. 保存待删除的节点
del_node = cur->next;
// 4. 断开 del_node 节点
cur->next = del_node->next;
// 5. 删除节点
delete del_node;
// 6. 编程规范:防止出现野指针
del_node = nullptr;
} else {
// 7. 没找到相同元素就继续向后遍历
cur = cur->next;
}
}
return head;
}
};
复杂度分析
时间复杂度:O(n),只需要一次遍历 n 个链表节点 空间复杂度:O(1),只使用常数的内存指针单位
上述内容就是LeetCode中如何删除排序链表中的重复元素,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注行业资讯频道。
节点
元素
指针
排序
复杂
复杂度
相同
内容
技能
知识
示例
结点
输入
输出
不对
简明
简明扼要
内存
副本
单位
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
快快网络安全教育
网络安全装什么虚拟机
关于网络安全的有关论述
武汉crm软件开发机构
饿了么数据库设计图
数据库删除第3行数据库
dnf韩服服务器设置
城市交通网络安全
做单片机软件开发前景如何
数据库查询工龄
手机网络安全问题解析
当下网络服务器品牌
宣传普及网络安全知识
在线网络技术咨询联系人
河南周口软件开发专业
临沂蓝讯互联网科技有限公司
滴滴网络安全审查的内容
网络安全报考什么
linux开启数据库服务
扬州大数据库安全
gis服务器新建不了
7种软件开发模型的主要特点
我的世界服务器变成创造的指令
服务器版本的ubuntu
很长的数字怎么加入数据库
大智慧互联网金融科技
软件开发项目管理的文档
逻辑思维软件开发
天壹科技与互联网
虎豹骑登录服务器