删除链表中重复的结点 牛客网 剑指Offer
- 题目描述
- 在一个排序的链表中,存在重复的结点,请删除该链表中重复的结点,重复的结点不保留,返回链表头指针。 例如,链表1->2->3->3->4->4->5 处理后为 1->2->5
# class ListNode:
# def __init__(self, x):
# self.val = x
# self.next = None
class Solution:
def deleteDuplication(self, pHead):
if pHead == None:
return
preHead = None
pNode = pHead
while pNode !=None:
needDelete = False
nextNode = pNode.next
if nextNode != None and nextNode.val == pNode.val:
needDelete = True
if needDelete == False:
preHead = pNode
pNode = pNode.next
else:
nodeVal = pNode.val
pToBeDel = pNode
while pToBeDel != None and pToBeDel.val == nodeVal:
pToBeDel = pToBeDel.next
if preHead == None:
pHead = pToBeDel
else:
preHead.next = pToBeDel
pNode = pToBeDel
return pHead

本文介绍了一种算法,用于删除排序链表中的重复节点,只保留唯一节点,实现链表的精简处理。通过一个示例,展示了从1->2->3->3->4->4->5变为1->2->5的过程。
1739

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



