mirror of
https://gitee.com/coder-xiaomo/leetcode-problemset
synced 2025-01-26 02:00:27 +08:00
45 lines
1.5 KiB
HTML
45 lines
1.5 KiB
HTML
|
<p>设计一个 map ,满足以下几点:</p>
|
|||
|
|
|||
|
<ul>
|
|||
|
<li>字符串表示键,整数表示值</li>
|
|||
|
<li>返回具有前缀等于给定字符串的键的值的总和</li>
|
|||
|
</ul>
|
|||
|
|
|||
|
<p>实现一个 <code>MapSum</code> 类:</p>
|
|||
|
|
|||
|
<ul>
|
|||
|
<li><code>MapSum()</code> 初始化 <code>MapSum</code> 对象</li>
|
|||
|
<li><code>void insert(String key, int val)</code> 插入 <code>key-val</code> 键值对,字符串表示键 <code>key</code> ,整数表示值 <code>val</code> 。如果键 <code>key</code> 已经存在,那么原来的键值对 <code>key-value</code> 将被替代成新的键值对。</li>
|
|||
|
<li><code>int sum(string prefix)</code> 返回所有以该前缀 <code>prefix</code> 开头的键 <code>key</code> 的值的总和。</li>
|
|||
|
</ul>
|
|||
|
|
|||
|
<p> </p>
|
|||
|
|
|||
|
<p><strong>示例 1:</strong></p>
|
|||
|
|
|||
|
<pre>
|
|||
|
<strong>输入:</strong>
|
|||
|
["MapSum", "insert", "sum", "insert", "sum"]
|
|||
|
[[], ["apple", 3], ["ap"], ["app", 2], ["ap"]]
|
|||
|
<strong>输出:</strong>
|
|||
|
[null, null, 3, null, 5]
|
|||
|
|
|||
|
<strong>解释:</strong>
|
|||
|
MapSum mapSum = new MapSum();
|
|||
|
mapSum.insert("apple", 3);
|
|||
|
mapSum.sum("ap"); // 返回 3 (<u>ap</u>ple = 3)
|
|||
|
mapSum.insert("app", 2);
|
|||
|
mapSum.sum("ap"); // 返回 5 (<u>ap</u>ple + <u>ap</u>p = 3 + 2 = 5)
|
|||
|
</pre>
|
|||
|
|
|||
|
<p> </p>
|
|||
|
|
|||
|
<p><strong>提示:</strong></p>
|
|||
|
|
|||
|
<ul>
|
|||
|
<li><code>1 <= key.length, prefix.length <= 50</code></li>
|
|||
|
<li><code>key</code> 和 <code>prefix</code> 仅由小写英文字母组成</li>
|
|||
|
<li><code>1 <= val <= 1000</code></li>
|
|||
|
<li>最多调用 <code>50</code> 次 <code>insert</code> 和 <code>sum</code></li>
|
|||
|
</ul>
|