LeetCode第83题删除排序链表中的重复元素

继续打卡算法题,今天学习的是第83题删除排序链表中的重复元素,这道题目是道简单题。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码思维和编码能力有一些提升。

分析一波题目

本题如果使用hashmap存储已经存在的元素,使用一个新链表构建不重复的元素,这种解法很好理解。不过使用了额外空间,如果可以在原链表上操作就最佳了。 我们可以使用双指针的思路来实现这种解法。一个指针在前,一个指针在后。如果和前面的指针相同,则去除当前阶段。

如果有重复节点,需要去除重复的,通过修改prev.next指针curr节点指针就可以移除

本题解题技巧

1、使用前后双指针,判断是否重复,并且完成去重的逻辑。

编码解决

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode deleteDuplicates(ListNode head) {
        //特殊情况
        if(head == null || head.next == null) {
            return head;
        }
        ListNode dumy = new ListNode(0, head);
        ListNode prev = head;
        ListNode curr = head.next;

        while(curr != null ) {
            //重复的情况,移除当前重复元素
            if(curr.val == prev.val) {
              ListNode temp =  curr.next;
              prev.next = temp;
              curr = temp;
            } else {
                //不重复的情况
                ListNode temp =  curr.next;
                prev = curr;
                curr = temp;
            }
        }

        return dumy.next;

    }
}

总结

1、双指针解决有序数组去重复,有序链表去重都具备一样的效果,解法比较巧妙,性能比较高,双指针法相关的题目也是面试中比较常问的题目

相关推荐
码不停蹄的玄黓几秒前
SpringBoot 自动装配原理
java·spring boot·后端
XovH3 分钟前
Docker 从 0 到 1 再到 Kubernetes 实战:深入理解 Docker 镜像和分层结构
后端
来自上海的这位朋友9 分钟前
用 Three.js 做一个 Web 3D 非对称追猎 Demo:从场景、角色到手感调试
后端·游戏开发·three.js
qingyulee12 分钟前
线性回归、决策树
人工智能·算法·线性回归
SimonKing14 分钟前
别再把业务逻辑写进回调接口了!支付回调的正确打开方式
java·后端·程序员
来自上海的这位朋友19 分钟前
Spring Boot + MySQL 搭一个多人游戏后端:登录、房间、匹配、对局和成长系统
前端·后端·three.js
Zhang~Ling19 分钟前
C++ 继承机制详解下:多继承、虚继承与菱形继承底层原理
开发语言·c++·算法
来自上海的这位朋友20 分钟前
浏览器里的实时对局同步:WildHunt 的 WebSocket、输入序号与服务端快照
前端·javascript·后端
西安邮电大学21 分钟前
2026华为OD机考真题附答案-计算数列位置N的值
java·算法
chasdream22 分钟前
Doris批量导入慢?Spring Boot整合Doris Routine Load是如何提升数据导入性能
后端·数据分析