牛客top101题---删除有序链表中重复的元素-II (java)

Posted 小样5411

tags:

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

题目


对比删除有序链表中重复的元素-I,I是删除只留一个,II是重复就全删,前提都是升序链表。

题解

这题top101中官方解答如下,但只用了一个cur指针,比较是否重复全用cur.next和cur.next.next,这样理解起来就不那么直观了,还是用两个指针会更好理解,故记录下自己写的版本,top101.pdf文档中绝大部分的题解还是十分详细且易懂的。

public class Solution 
    /**
     * 
     * @param head ListNode类 
     * @return ListNode类
     */
    public ListNode deleteDuplicates (ListNode head) 
        // 直接比较删除法
        if(head == null || head.next == null)
            return head;//空或只有一个节点
        
        //由于head节点就可能重复,故需要加头节点
        ListNode res = new ListNode(-1);
        res.next = head;
        ListNode pre = res;
        ListNode cur = head;
        while(cur != null && cur.next != null)
            if(cur.val == cur.next.val)
                //跳过相同的元素
                int temp = cur.val;
                //前面是防止走到空还赋值
                while(cur.next != null && temp == cur.next.val)
                    cur = cur.next;
                
                pre.next = cur.next;//删除
                cur = cur.next;//cur最后停在重复的最后一个,所以需要后移到下一个不重复的
            else
                //不相同,则正常后移
                pre = cur;
                cur = cur.next;
            
            
        
        return res.next;
    

开发者涨薪指南 48位大咖的思考法则、工作方式、逻辑体系

以上是关于牛客top101题---删除有序链表中重复的元素-II (java)的主要内容,如果未能解决你的问题,请参考以下文章

牛客top101题---删除有序链表中重复的元素-II (java)

#yyds干货盘点# 面试必刷TOP101:删除有序链表中重复的元素-I

删除有序链表中重复的元素(NC25/考察次数Top62/难度简单)

删除有序链表中重复的元素(NC25/考察次数Top62/难度简单)

删除有序链表中重复的元素-II(NC24/考察次数Top72/难度中等)

删除有序链表中重复的元素-II(NC24/考察次数Top72/难度中等)