当前位置: 代码迷 >> 综合 >> LeetCode刷题(0002)---677. 键值映射,python3
  详细解决方案

LeetCode刷题(0002)---677. 键值映射,python3

热度:58   发布时间:2024-02-07 21:59:09.0

目录

  • LeetCode---677. 键值映射,python3
    • 01题目描述:
    • 02题目分析:
            • 重点理解 :同时获取key和value使用的item()函数获取到元组,然后拆包!
    • 03解答:
    • 04运行结果:
        • 1.时间运行图:
        • 2.内存使用情况
    • 05结语:

LeetCode—677. 键值映射,python3

01题目描述:

实现一个 MapSum 类里的两个方法,insert 和 sum。

对于方法 insert,你将得到一对(字符串,整数)的键值对。字符串表示键,整数表示值。如果键已经存在,那么原来的键值对将被替代成新的键值对。

对于方法 sum,你将得到一个表示前缀的字符串,你需要返回所有以该前缀开头的键的值的总和。


示例 1:输入: insert("apple", 3), 输出: Null
输入: sum("ap"), 输出: 3
输入: insert("app", 2), 输出: Null
输入: sum("ap"), 输出: 5

02题目分析:

1、实现两个功能,第一个是插入 insert ,字典 my_dict[key]=val 本身的就是:对于已经存在的覆盖(修改),对于不存在的添加!所以这一个很简单实现!
2、sum 方法就是计算以什么什么为 前缀 的,这一个就很容易的想到了 startwith
循环遍历全部字典。匹配 key 的前缀,获取 val 的值,然后求和。这一边一个获取keyval有很多的方式,我使用了一种很快捷,方便的方式j使用 items() 方法的遍历:items() 方法把字典中每对keyvalue组成一个元组,并把这些元组放在列表中返回。之后for循环同时拆包取出 key , value

重点理解 :同时获取key和value使用的item()函数获取到元组,然后拆包!

03解答:


class MapSum():def __init__(self):"""Initialize your data structure here."""self.my_dict = {}# self.resoult = 0def insert(self, key: str, val: int) -> None:self.my_dict[key]=val# print(self.my_dict)def sum(self, prefix: str) -> int:result = 0for key,val in self.my_dict.items():if key.startswith(prefix):result += valreturn result# Your MapSum object will be instantiated and called as such:
# obj = MapSum()
# obj.insert(key,val)
# param_2 = obj.sum(prefix)

04运行结果:

1.时间运行图:

在这里插入图片描述

2.内存使用情况

在这里插入图片描述

05结语:

个人记录,新手入门,多多学习,欢迎大家交流探讨!
个人网站: http://106.54.78.238/
song_of _sea的个人网站 http://106.54.78.238/