leetcode 83. 删除排序链表中的重复元素
给定一个已排序的链表的头 head
, 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。
示例 1:
输入:head = [1,1,2] 输出:[1,2]
示例 2:
输入:head = [1,1,2,3,3] 输出:[1,2,3]
提示:
- 链表中节点数目在范围
[0, 300]
内 -100 <= Node.val <= 100
- 题目数据保证链表已经按升序 排列
# Definition for singly-linked list. # class ListNode: # def __init__(self, val=0, next=None): # self.val = val # self.next = next class Solution:def deleteDuplicates(self, head: Optional[ListNode]) -> Optional[ListNode]:if(head==None):return headslow = head //快慢指针fast = head.nextwhile(fast):if(slow.val==fast.val):slow.next = fast.nextelse:slow = fast //注意,这里交换规则fast = slow.next //无论是否交换,快指针都要前进一return head