82. 删除排序链表中的重复元素 II
给定一个排序链表,删除所有含有重复数字的节点,只保留原始链表中 没有重复出现 的数字。
示例 1:
输入: 1->2->3->3->4->4->5
输出: 1->2->5
示例 2:
输入: 1->1->1->2->3
输出: 2->3
class Solution:
def deleteDuplicates(self, head: ListNode) -> ListNode:
dummy = pre = ListNode(0)
dummy.next = head
while head and head.next:
if head.val == head.next.val:
while head and head.next and head.val == head.next.val:
head = head.next
head = head.next
pre.next = head
else:
pre = pre.next
head = head.next
return dummy.next
本文介绍了一种算法,用于删除排序链表中所有重复的元素,仅保留未重复的数字。通过示例展示了输入为1->2->3->3->4->4->5时,输出为1->2->5;当输入为1->1->1->2->3时,输出为2->3。文章详细解析了如何使用伪头节点简化边界条件处理,以及如何在遍历链表时高效地移除重复元素。
1119

被折叠的 条评论
为什么被折叠?



