mirror of
				https://gitee.com/coder-xiaomo/leetcode-problemset
				synced 2025-10-25 14:58:56 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			43 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			43 lines
		
	
	
		
			1.7 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
| <p>Design a map that allows you to do the following:</p>
 | |
| 
 | |
| <ul>
 | |
| 	<li>Maps a string key to a given value.</li>
 | |
| 	<li>Returns the sum of the values that have a key with a prefix equal to a given string.</li>
 | |
| </ul>
 | |
| 
 | |
| <p>Implement the <code>MapSum</code> class:</p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>MapSum()</code> Initializes the <code>MapSum</code> object.</li>
 | |
| 	<li><code>void insert(String key, int val)</code> Inserts the <code>key-val</code> pair into the map. If the <code>key</code> already existed, the original <code>key-value</code> pair will be overridden to the new one.</li>
 | |
| 	<li><code>int sum(string prefix)</code> Returns the sum of all the pairs' value whose <code>key</code> starts with the <code>prefix</code>.</li>
 | |
| </ul>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong class="example">Example 1:</strong></p>
 | |
| 
 | |
| <pre>
 | |
| <strong>Input</strong>
 | |
| ["MapSum", "insert", "sum", "insert", "sum"]
 | |
| [[], ["apple", 3], ["ap"], ["app", 2], ["ap"]]
 | |
| <strong>Output</strong>
 | |
| [null, null, 3, null, 5]
 | |
| 
 | |
| <strong>Explanation</strong>
 | |
| MapSum mapSum = new MapSum();
 | |
| mapSum.insert("apple", 3);  
 | |
| mapSum.sum("ap");           // return 3 (<u>ap</u>ple = 3)
 | |
| mapSum.insert("app", 2);    
 | |
| mapSum.sum("ap");           // return 5 (<u>ap</u>ple + <u>ap</u>p = 3 + 2 = 5)
 | |
| </pre>
 | |
| 
 | |
| <p> </p>
 | |
| <p><strong>Constraints:</strong></p>
 | |
| 
 | |
| <ul>
 | |
| 	<li><code>1 <= key.length, prefix.length <= 50</code></li>
 | |
| 	<li><code>key</code> and <code>prefix</code> consist of only lowercase English letters.</li>
 | |
| 	<li><code>1 <= val <= 1000</code></li>
 | |
| 	<li>At most <code>50</code> calls will be made to <code>insert</code> and <code>sum</code>.</li>
 | |
| </ul>
 |