LeetCode:83. 删除排序链表中的重复元素

简介

题目链接:https://leetcode.cn/problems/remove-duplicates-from-sorted-list/description/

解决方式:链表 + 双指针

这是作者学习众多大神的思路进行解题的步骤,很推荐大家解题的时候去看看题解里面大佬们的思路、想法!

推荐查看画手大鹏大佬所作题解。

双指针

解题思路:这题也是用的双指针,不过不一样的是该题的双指针是当前节点和节点的指针域。这么做有一个好处,就是移动到下一个节点时,可以只移动当前节点就好了,不用移动两次,下一个节点的指针域本身就是下一个位置正确的指针。

java 复制代码
class Solution {
    public ListNode deleteDuplicates(ListNode head) {
        ListNode pre = head;
        // pre 本身是一个指针,pre.next 相当于另外一个指针
        while(pre != null && pre.next != null){ // 开始与结束边界
            if(pre.val == pre.next.val){
                // 节点值相等,移除后一个相等的节点
                // 移除后节点不移动,立足当前节点,看看是否后续新节点是否与当前节点仍然相等。是的话,继续移除。
                pre.next = pre.next.next;
            }else{
                // 直到当前节点值与下一个节点的节点值不等,才移动到下一个节点
                pre = pre.next;
            }
        }
        // 返回结果
        return head;
    }
}
相关推荐
地平线开发者9 小时前
J6B vio scenario sample
算法
BothSavage21 小时前
Trae远程开发中DeepSeek自定义模型4054错误的排查与修复
算法
小林ixn21 小时前
从暴力到KMP:一道题彻底搞懂字符串匹配的前世今生
算法
烬羽1 天前
字符串算法入门:从反转字符串到回文判断,面试不再慌
算法·面试
先吃饱再说2 天前
判断回文字符串,从一行代码到双指针优化
算法
黄敬峰2 天前
深入理解算法核心:从递归思想、数组扁平化到快速排序
算法
得物技术2 天前
从狂野代码到按目标生产:得物推荐 AI Harness 的工程化实践|AICon 演讲整理
人工智能·算法·架构
AI小老六2 天前
SkillOpt 架构拆解:把 Skill 文本当参数,用执行轨迹训练 Agent
后端·算法·ai编程