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;
    }
}
相关推荐
008爬虫实战录10 小时前
【码上爬】 题十:魔改算法 堆栈分析,找加密值过程详解
前端·python·算法
chao18984410 小时前
基于狮蚁群算法(ALO)的火电机组功能调度实现
人工智能·算法
Deep-w10 小时前
【MATLAB】含光伏 - 储能的家庭/工业微电网能量管理仿真研究
开发语言·算法·matlab
阿文的代码库10 小时前
换根技巧实例分析:最小高度树
算法·动态规划
dyxal10 小时前
Louvain 算法:让网络自己“报团取暖”的发现者
开发语言·算法
计算机安禾10 小时前
【c++面向对象编程】第41篇:函数模板与类模板:泛型编程的基石
开发语言·c++·算法
SilentSamsara11 小时前
属性查找顺序:实例 → 类 → 父类的完整 MRO
开发语言·python·算法·青少年编程
不知名的老吴11 小时前
浅谈:树形动态规划中的换根技巧
算法·动态规划
一条大祥脚11 小时前
2021-2022 ICPC Southwestern Europe Regional Contest
算法·深度优先·图论
罗湖老棍子11 小时前
The xor-longest Path(信息学奥赛一本通- P1478)
算法·字符串·字典树··lca最近公共祖先