继续打卡算法题,今天学习的是第83题删除排序链表中的重复元素,这道题目是道简单题
。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码思维和编码能力有一些提升。
分析一波题目
本题如果使用hashmap存储已经存在的元素,使用一个新链表构建不重复的元素,这种解法很好理解。不过使用了额外空间,如果可以在原链表
上操作就最佳了。 我们可以使用双指针的思路来实现这种解法。一个指针在前,一个指针在后。如果和前面的指针相同,则去除当前阶段。
如果有重复节点,需要去除重复的,通过修改prev.next指针
和curr节点指针
就可以移除
本题解题技巧
1、使用前后双指针,判断是否重复,并且完成去重的逻辑。
编码解决
/**
* 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、双指针解决有序数组去重复,有序链表去重都具备一样的效果,解法比较巧妙,性能比较高,双指针法相关的题目也是面试中比较常问的题目