zoukankan      html  css  js  c++  java
  • Leetcode练习(python):链表类:第82题:删除排序链表中的重复元素 II:给定一个排序链表,删除所有含有重复数字的节点,只保留原始链表中 没有重复出现 的数字。

    题目:
    删除排序链表中的重复元素 II:给定一个排序链表,删除所有含有重复数字的节点,只保留原始链表中 没有重复出现 的数字。
    思路:
    懒人思维,使用哈希表。
    程序:
    # 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
            myHashMap = dict()
            myNode = head
            while myNode:
                if myNode.val in myHashMap:
                    myHashMap[myNode.val] = myHashMap.get(myNode.val, 0) + 1
                else:
                    myHashMap[myNode.val] = myHashMap.get(myNode.val, 1)
                myNode = myNode.next
            myNewNode = head
            myNewHead = None
            myNewCurrent = None
            while myNewNode:
                if myHashMap[myNewNode.val] == 1:
                    node = ListNode(myNewNode.val)
                    if myNewHead is None:
                        myNewHead = node
                        myNewCurrent = myNewHead
                    else:
                        myNewCurrent.next = node
                        myNewCurrent = myNewCurrent.next
                myNewNode = myNewNode.next
            return myNewHead
  • 相关阅读:
    Design and Implementation of the Sun Network File System
    Flash: An Efficient and Portable Web Server
    Java集合框架练习-计算表达式的值
    后缀数组专题训练
    经典问题-生产者和消费者问题
    ubuntu14.04下配置Java环境以及安装最新版本的eclipse
    Java多线程之CountDownLatch学习
    ZooKeerper学习之Watcher
    ZooKeeper之FastLeaderElection算法详解
    python获取当天日期进行格式转换
  • 原文地址:https://www.cnblogs.com/zhuozige/p/12818743.html
Copyright © 2011-2022 走看看