leetcode刷题-82.删除排序链表中的重复元素 II

题目

给定一个排序链表,删除所有含有重复数字的节点,只保留原始链表中 没有重复出现 的数字。

示例 1:

输入: 1->2->3->3->4->4->5
输出: 1->2->5

思路

不断的遍历链表中的每个元素,若该元素的值和前后元素的值都不相等,则该元素就是独一无二的,把它加入结果链表里。

在实现的过程中,在提供的链表前新增一个空节点开始遍历。当节点运行到i时,考验的是i.next的与前后值的关系。

实现

# Definition for singly-linked list.
# class ListNode:
#     def __init__(self, x):
#         self.val = x
#         self.next = None

class Solution:
    def deleteDuplicates(self, head: ListNode) -> ListNode:
        if not head:
            return None
        result = res_pointer = ListNode(None)
        pointer = ListNode(None)
        pointer.next = head
        while pointer.next.next:
            if pointer.val != pointer.next.val != pointer.next.next.val:
                res_pointer.next = pointer.next
                res_pointer = res_pointer.next
            pointer = pointer.next
        if pointer.val != pointer.next.val:
            res_pointer.next = pointer.next
            res_pointer = res_pointer.next
        res_pointer.next = None
        return result.next

 

posted @ 2020-08-12 14:25  maoguai  阅读(75)  评论(0编辑  收藏  举报