牛客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;
以上是关于牛客top101题---删除有序链表中重复的元素-II (java)的主要内容,如果未能解决你的问题,请参考以下文章
牛客top101题---删除有序链表中重复的元素-II (java)
#yyds干货盘点# 面试必刷TOP101:删除有序链表中重复的元素-I
删除有序链表中重复的元素(NC25/考察次数Top62/难度简单)
删除有序链表中重复的元素(NC25/考察次数Top62/难度简单)