链表面试-删除链表中重复的节点(常考题)
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;//不要虚拟节点,从虚拟节点下一个作为头结点返回
}
}
以上是关于链表面试-删除链表中重复的节点(常考题)的主要内容,如果未能解决你的问题,请参考以下文章
剑指Offer-代码的完整性面试题18.2:删除链表中的重复节点