剑指Offer(Python多种思路实现):删除链表中的节点

剑指Offer(Python多种思路实现):删除链表中的节点

面试18题:

题目:删除链表中的节点

题一:在O(1)时间内删除链表节点。给定单向链表的头指针和一个节点指针,定义一个函数在O(1)时间内删除该节点。

解题思路一:先把i的下一个节点j的内容复制到i,然后把i的指针指向节点j的下一个节点。此时再删除节点j,其效果等同于把节点i删除了。

class ListNode:
    def __init__(self):
        self.value = None
        self.next = None
class Solution:
    def deleteNode(self, head_node, del_node):
        if not (head_node and del_node):
            return False
        # 待删除节点不是尾节点
        if del_node.next:
            temp = del_node.next
            del_node.value = temp.value
            del_node.next = temp.next
            temp = None
            temp.next = None
            # del_node.value = del_node.next.value
            # del_node.next = del_node.next.next
        
        # 链表只有一个节点,删除头节点(也是尾节点)
        elif del_node == head_node:
            head_node = None
            del_node = None
        
        #链表中有多个节点,删除尾节点
        else:
            node = head_node
            while node.next!=del_node:
                node = node.next
            node.next = None
            del_node = None
        
        return head_node

题目:删除链表中重复的节点。

题:在一个排序的链表中,请删除重复的节点,如1-2-3-3-4-4-5在重复的节点被删除后为1-2-5。

解题思路一:将链表元素保存在列表中,然后过滤掉出现次数大于1的值,只保留出现次数为1的值,再将新的列表建成链表的形式。

class Solution:
    def deleteDuplication(self, pHead):
        # write code here
        res=[]
        while pHead:
            res.append(pHead.val)
            pHead=pHead.next
        res=list(filter(lambda c:res.count(c)==1,res))
        
        newList=ListNode(0)
        pre=newList
        for i in res:
            node=ListNode(i)
            pre.next=node
            pre=pre.next
        return newList.next
            

解题思路二:运用链表的操作,确保将重复的节点略过,始终连接不重复的值。

class Solution:
    def deleteDuplication(self, pHead):
        # write code here
        first=ListNode(-1)
        first.next=pHead
        last=first
        
        while pHead and pHead.next:
            if pHead.val == pHead.next.val:
                val=pHead.val
                while pHead and pHead.val==val:
                    pHead=pHead.next
                last.next=pHead
            else:
                last=pHead
                pHead=pHead.next
        return first.next

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值