链表面试-删除链表中重复的节点(常考题)

Posted eaglewgs

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了链表面试-删除链表中重复的节点(常考题)相关的知识,希望对你有一定的参考价值。

题目描述:

在一个排序的链表中,存在重复的节点,请删除该链表中重复的节点,重复的节点不保留,返回链表头指针。例如,链表1->2->3->3->4->4->5处理后为1->2->5

示例描述:

输入:{1,2,3,3,4,4,5}
返回值:{1,2,5}

  • 最后一个节点不是重复的节点的情况:
  • 最后一个节点也是重复的节点的情况:

此时就需要把最后的节点的next置为null,所以最后要增加一步,无论是这两种中的那种情况,一律在最后加一个tmp.next = null;

个人理解:

  • 该题的新颖方法是引入了一个虚拟头结点,虚拟头结点是计算过程中链表的头结点,但是在最后返回的时候不将它作为真实的头结点返回,而是将它舍弃,将它后面的一个节点作为真实的头节点返回,说白了只是为了方便过程操作方便而已。
  • 然后要明白两个while循环的作用,里面的while循环可以将连续重复的数字一一跳过,并且能多跳一步,这里自己画个链表体会下,多敲下代码感受就好了。

题解实现:

/*
 public class ListNode {
    int val;
    ListNode next = null;

    ListNode(int val) {
        this.val = val;
    }
}
*/
public class Solution {
    public ListNode deleteDuplication(ListNode pHead) {
        ListNode cur = pHead;
        ListNode newHead = new ListNode(-1);//定义一个虚拟头节点
        ListNode tmp = newHead;
        while(cur != null){
            if(cur.next != null&& cur.val==cur.next.val){//cur.next != null是为了防止空指针异常
                while (cur.next!= null&& cur.val == cur.next.val){//这是连续重复的,cur.next!= null也是为了防止空指针异常
                    cur = cur.next;
                }
                cur = cur.next;//要多走一步
            }else {
                tmp.next = cur;
                tmp = tmp.next;
                cur = cur.next;
            }
        }
        tmp.next = null;//为了防止最后的也是重复的,这样需要把对应的.next置为null
        return newHead.next;//不要虚拟节点,从虚拟节点下一个作为头结点返回
    }
}

以上是关于链表面试-删除链表中重复的节点(常考题)的主要内容,如果未能解决你的问题,请参考以下文章

java 数据结构常考的OJ 链表,重点!重点!!!

剑指Offer-代码的完整性面试题18.2:删除链表中的重复节点

[程序员代码面试指南]链表问题-删除无序链表中重复出现的节点

面试题:删除链表中的重复节点

剑指offer——面试题18.1:删除链表中重复的节点

链表经典面试题(反转链表,中间节点,倒数第k个节点,合并分割链表,删除重复节点)