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

题目描述:

在一个排序的链表中,存在重复的节点,请删除该链表中重复的节点,重复的节点不保留,返回链表头指针。例如,链表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;//不要虚拟节点,从虚拟节点下一个作为头结点返回
    }
}
  • 4
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值