LeetCode中如何删除排序链表中的重复元素
发表于:2024-11-28 作者:千家信息网编辑
千家信息网最后更新 2024年11月28日,本篇文章为大家展示了LeetCode中如何删除排序链表中的重复元素,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。一、题目描述给定一个排序链表,删除所有重复的元
千家信息网最后更新 2024年11月28日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安全错误
数据库的锁怎样保障安全
服务器安全擦除能恢复么
网络技术优盘批发
巨杉数据库为什么越查询越慢
mayhem自动网络安全平台
博雅高考数据库2021江苏文科
网络安全鉴定案例
公司数据库删了
数据库系统与应用ER图
大学校园网络安全意识
深圳服务器不锈钢外壳厂商
软件开发公司的寿命
网络技术应用导学案
西安直销软件开发流程
景色滤镜软件开发
对于软件开发工作的理解
计算机网络技术职业教材
服务器日志分类
gis软件开发实例
腾讯网络安全月免费改名
网络安全建设评价体系
哪个软件开发实力好
网络技术flash动画
网络安全鉴定案例
遵义凤冈学数据库测试月薪超万
嘉定区无线网络技术电话
数据库R S和RS
网络安全宣传周怎么样
文旅局网络安全人民活动总结
数据库设计遵循的原则
我的世界狼人行动4在哪个服务器