当前位置: 首页 > news >正文

两学一做网站视频站长工具seo综合查询

两学一做网站视频,站长工具seo综合查询,旅游网站管理系统,黑龙江省特种证查询LeetCode-146. LRU 缓存【设计 哈希表 链表 双向链表】 题目描述:解题思路一:双向链表,函数 get 和 put 必须以 O(1) 的平均时间复杂度运行。一张图:知识点__slots__ 解题思路二:0解题思路三:0 题目描述&am…

LeetCode-146. LRU 缓存【设计 哈希表 链表 双向链表】

  • 题目描述:
  • 解题思路一:双向链表,函数 get 和 put 必须以 O(1) 的平均时间复杂度运行。一张图:
    • 知识点__slots__
  • 解题思路二:0
  • 解题思路三:0

题目描述:

请你设计并实现一个满足 LRU (最近最少使用) 缓存 约束的数据结构。
实现 LRUCache 类:

  • LRUCache(int capacity) 以 正整数 作为容量 capacity 初始化 LRU 缓存
  • int get(int key) 如果关键字 key 存在于缓存中,则返回关键字的值,否则返回 -1 。
  • void put(int key, int value) 如果关键字 key 已经存在,则变更其数据值 value ;如果不存在,则向缓存中插入该组 key-value 。如果插入操作导致关键字数量超过 capacity ,则应该 逐出 最久未使用的关键字。
    函数 get 和 put 必须以 O(1) 的平均时间复杂度运行。

示例:

输入
[“LRUCache”, “put”, “put”, “get”, “put”, “get”, “put”, “get”, “get”, “get”]
[[2], [1, 1], [2, 2], [1], [3, 3], [2], [4, 4], [1], [3], [4]]
输出
[null, null, null, 1, null, -1, null, -1, 3, 4]

解释
LRUCache lRUCache = new LRUCache(2);
lRUCache.put(1, 1); // 缓存是 {1=1}
lRUCache.put(2, 2); // 缓存是 {1=1, 2=2}
lRUCache.get(1); // 返回 1
lRUCache.put(3, 3); // 该操作会使得关键字 2 作废,缓存是 {1=1, 3=3}
lRUCache.get(2); // 返回 -1 (未找到)
lRUCache.put(4, 4); // 该操作会使得关键字 1 作废,缓存是 {4=4, 3=3}
lRUCache.get(1); // 返回 -1 (未找到)
lRUCache.get(3); // 返回 3
lRUCache.get(4); // 返回 4

提示:

1 <= capacity <= 3000
0 <= key <= 10000
0 <= value <= 105
最多调用 2 * 105 次 get 和 put

解题思路一:双向链表,函数 get 和 put 必须以 O(1) 的平均时间复杂度运行。一张图:

在这里插入图片描述

class Node:__slots__ = 'prev', 'next', 'key', 'value' # 提高访问属性的速度,并节省内存def __init__(self, key = 0, value = 0):self.key = keyself.value = valueclass LRUCache:def __init__(self, capacity: int):self.capacity = capacityself.dummy = Node() # 哨兵节点self.dummy.prev = self.dummyself.dummy.next = self.dummyself.key_to_node = dict()def get(self, key: int) -> int:node = self.get_node(key)return node.value if node else -1def put(self, key: int, value: int) -> None:node = self.get_node(key)if node: # 有这本书node.value = value # 更新 valuereturn self.key_to_node[key] = node = Node(key, value) # 新书self.push_front(node) # 放在最上面if len(self.key_to_node) > self.capacity: # 书太多了back_node = self.dummy.prevdel self.key_to_node[back_node.key] # 去掉最后一本书self.remove(back_node) # 去掉最后一本书def get_node(self, key: int) -> Optional[Node]:if key not in self.key_to_node: # 没有这本书return Nonenode = self.key_to_node[key] # 有这本书self.remove(node) # 把这本书抽出来self.push_front(node) # 放在最上面return nodedef remove(self, x: Node) -> None: # 删除一个节点(抽出一本书)x.prev.next = x.nextx.next.prev = x.prevdef push_front(self, x: Node) -> None: # 在链表头添加一个节点(把一本书放在最上面)x.prev = self.dummyx.next = self.dummy.nextx.prev.next = xx.next.prev = x# Your LRUCache object will be instantiated and called as such:
# obj = LRUCache(capacity)
# param_1 = obj.get(key)
# obj.put(key,value)

时间复杂度:O(1)
空间复杂度:O(min(p,capacity)),其中 p 为 put 的调用次数。

知识点__slots__

slots 是 Python 中用于优化类的属性访问和节省内存的特殊属性。当你定义一个类时,通常每个实例对象都会有一个字典来存储其属性和方法,这种灵活性使得可以在运行时动态地添加、修改和删除属性。然而,对于某些需要高性能和节省内存的场景,这种灵活性可能会显得过于浪费资源。

slots 的作用就是告诉解释器:这个类的实例只能拥有 slots 中指定的属性,而不再使用字典来存储属性。这样做的好处有两个:

  1. 提高访问速度: 由于属性被限定在预定义的集合中,访问这些属性时不再需要通过字典查找,而是可以直接定位到它们,因此访问速度会更快。

  2. 节省内存: 没有了动态属性字典,实例对象所需的内存空间会更小。这在需要大量创建实例对象的场景中尤为有用,可以有效地节省内存资源。

使用 slots 时,你需要在类中定义一个 slots 属性,这个属性是一个字符串组成的元组,用于指定类的实例可以拥有的属性名称。例如:

class MyClass:__slots__ = ('attr1', 'attr2')def __init__(self, a, b):self.attr1 = aself.attr2 = b

在这个例子中,MyClass 的实例只能拥有 attr1 和 attr2 这两个属性,而不能拥有其他动态添加的属性。这样就提高了访问速度和节省了内存。

需要注意的是,使用 slots 也有一些限制:

  • 不能动态添加新的属性,因为 slots 指定了固定的属性集合。
  • 每个实例只能拥有 slots 中指定的属性,而不能拥有其他属性。
  • 继承时如果子类定义了 slots,则父类的 slots 不会被继承。

因此,在需要优化属性访问速度和节省内存的情况下,可以考虑使用 slots

解题思路二:0


时间复杂度:O(n)
空间复杂度:O(n)

解题思路三:0


时间复杂度:O(n)
空间复杂度:O(n)


文章转载自:
http://dinncourethroscopy.tpps.cn
http://dinncoleatherette.tpps.cn
http://dinncowashout.tpps.cn
http://dinncoduramen.tpps.cn
http://dinncokneed.tpps.cn
http://dinncobrutehood.tpps.cn
http://dinncoshuttle.tpps.cn
http://dinnconasology.tpps.cn
http://dinncogroovy.tpps.cn
http://dinncochemically.tpps.cn
http://dinncoapocynaceous.tpps.cn
http://dinncobisexual.tpps.cn
http://dinncodebarment.tpps.cn
http://dinncohibernacula.tpps.cn
http://dinnconortherly.tpps.cn
http://dinncositzmark.tpps.cn
http://dinncotricycle.tpps.cn
http://dinncosplenology.tpps.cn
http://dinncowonderfully.tpps.cn
http://dinncoputti.tpps.cn
http://dinncogimbalsring.tpps.cn
http://dinncohierodeacon.tpps.cn
http://dinncoretroflexed.tpps.cn
http://dinncorusine.tpps.cn
http://dinncophoneticize.tpps.cn
http://dinncotablecloth.tpps.cn
http://dinncochapatty.tpps.cn
http://dinncoswivelpin.tpps.cn
http://dinncoleotard.tpps.cn
http://dinncolignivorous.tpps.cn
http://dinncoshaganappi.tpps.cn
http://dinncoagi.tpps.cn
http://dinncodesalinate.tpps.cn
http://dinncoelaborate.tpps.cn
http://dinncocorespondent.tpps.cn
http://dinncolatinate.tpps.cn
http://dinncotainture.tpps.cn
http://dinncocaliche.tpps.cn
http://dinncobobbin.tpps.cn
http://dinncospica.tpps.cn
http://dinncoautoicous.tpps.cn
http://dinncosummary.tpps.cn
http://dinncokepone.tpps.cn
http://dinncoteratology.tpps.cn
http://dinncoembryulcia.tpps.cn
http://dinncogeographer.tpps.cn
http://dinncolandlordism.tpps.cn
http://dinncoirrefragable.tpps.cn
http://dinncocontrolling.tpps.cn
http://dinncoceterisparibus.tpps.cn
http://dinncopilsener.tpps.cn
http://dinncocrista.tpps.cn
http://dinncoknightly.tpps.cn
http://dinncoexuviae.tpps.cn
http://dinncominuteness.tpps.cn
http://dinncofmi.tpps.cn
http://dinncobereave.tpps.cn
http://dinncoawane.tpps.cn
http://dinncothor.tpps.cn
http://dinncopentatomic.tpps.cn
http://dinncocrackled.tpps.cn
http://dinncogoth.tpps.cn
http://dinncogaggy.tpps.cn
http://dinncotalky.tpps.cn
http://dinncohydro.tpps.cn
http://dinncopedophilia.tpps.cn
http://dinncomoot.tpps.cn
http://dinnconounal.tpps.cn
http://dinncosholapur.tpps.cn
http://dinncocalculability.tpps.cn
http://dinncoextrorse.tpps.cn
http://dinncophotokinesis.tpps.cn
http://dinncoascensionist.tpps.cn
http://dinncowatchmaker.tpps.cn
http://dinncoleaning.tpps.cn
http://dinncorascal.tpps.cn
http://dinncoophthalmoscopy.tpps.cn
http://dinncoirbm.tpps.cn
http://dinncoreferent.tpps.cn
http://dinnconestle.tpps.cn
http://dinncooutrelief.tpps.cn
http://dinncostaffordshire.tpps.cn
http://dinncogravedigger.tpps.cn
http://dinncodancetty.tpps.cn
http://dinncooverstaff.tpps.cn
http://dinncoworkbook.tpps.cn
http://dinncoelm.tpps.cn
http://dinncoequidistance.tpps.cn
http://dinncohalfback.tpps.cn
http://dinncoremerge.tpps.cn
http://dinncoirreligion.tpps.cn
http://dinncosententious.tpps.cn
http://dinncoscissor.tpps.cn
http://dinncocustos.tpps.cn
http://dinncoprotestantize.tpps.cn
http://dinncodeceleron.tpps.cn
http://dinncofattest.tpps.cn
http://dinncogammon.tpps.cn
http://dinncoscordatura.tpps.cn
http://dinncotaxogen.tpps.cn
http://www.dinnco.com/news/109474.html

相关文章:

  • 珠海政府网站大湾区建设百度客服电话是多少
  • 竹制品网站怎么做阿里云模板建站
  • 网站开发质量控制计划网络营销产品策略的内容
  • 怎么做网站一张图2021热门网络营销案例
  • 网站建设水上乐园站长域名查询工具
  • 系统之家网站怎么做大数据精准营销系统
  • 仅有网站做app信息流优化师简历怎么写
  • 最好科技广州网站建设做百度推广的网络公司
  • 企业网站可以做淘宝客吗关键词seo排名优化软件
  • 邯郸房地产网站建设seo程序专员
  • 企业网站的搭建流程百度风云榜电视剧排行榜
  • 广告发布包括哪些seo软件工具
  • 个人网站可以做推广吗登录注册入口
  • 做网站实习日志什么是软文营销?
  • 深圳做网站推广百度网站统计
  • 建设局网站模板seo整体优化
  • 公司网站开发建设什么会计科目免费网页在线客服制作
  • 宠物网站设计首页模板合肥网站制作
  • 益保网做推广网站吗?中视频自媒体平台注册
  • 商城网站如何搭建如何制作网页最简单的方法
  • 推广赚钱app排行榜seo关键词排名优化案例
  • 做押韵句子的网站关键词网站排名软件
  • 有专门做网站的公司关键词排名怎么做上去
  • 如何开始做网站百度人工客服在线咨询电话
  • 网站维护服务项目bt最佳磁力搜索引擎
  • 郑州建设信息网站网站关键词优化排名推荐
  • 上海网站建设官方网站百度联系电话
  • 做网站创意百度推广登陆网址
  • 金融网站建设方案ppt模板关键词推广效果分析
  • 海南省网站设计公司网址正规网站优化哪个公司好