剑指offer系列之五十八:删除链表中重复的节点

题目描述

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

因为需要找到重复的节点,所以对链表进行遍历,而且在遍历的过程中需要对每个当前遍历的节点以及后面的节点进行比较直到遇到下一个节点不与当前节点重复。如果下一个节点与当前遍历的节点不重复,则继续遍历,直到把整个链表遍历结束。下面是具体的实现代码(已被牛客AC):

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

    ListNode(int val) {
        this.val = val;
    }
}

public class Solution {
    public ListNode deleteDuplication(ListNode pHead)
    {
        if(pHead == null) return pHead;
        ListNode firstNode = new ListNode(-1);
        firstNode.next = pHead;
        ListNode preNode = firstNode;
        ListNode curNode = pHead;
        while(curNode != null && curNode.next != null){
            if(curNode.val == curNode.next.val){
                int val = curNode.val;
                while(curNode != null && curNode.val == val){
                    curNode = curNode.next;
                }
                preNode.next = curNode;
            }else{
                preNode = curNode;
                curNode = curNode.next;
            }
        }
        return firstNode.next;
    }
}
上一篇:Java IO学习笔记:字符流


下一篇:掌握字符输入流:Reader | 带你学《Java语言高级特性》之五十六