# [706. 设计哈希映射](https://leetcode-cn.com/problems/design-hashmap) [English Version](/solution/0700-0799/0706.Design%20HashMap/README_EN.md) ## 题目描述 <!-- 这里写题目描述 --> <p>不使用任何内建的哈希表库设计一个哈希映射</p> <p>具体地说,你的设计应该包含以下的功能</p> <ul> <li><code>put(key, value)</code>:向哈希映射中插入(键,值)的数值对。如果键对应的值已经存在,更新这个值。</li> <li><code>get(key)</code>:返回给定的键所对应的值,如果映射中不包含这个键,返回-1。</li> <li><code>remove(key)</code>:如果映射中存在这个键,删除这个数值对。</li> </ul> <p><br /> <strong>示例:</strong></p> <pre> MyHashMap hashMap = new MyHashMap(); hashMap.put(1, 1); hashMap.put(2, 2); hashMap.get(1); // 返回 1 hashMap.get(3); // 返回 -1 (未找到) hashMap.put(2, 1); // 更新已有的值 hashMap.get(2); // 返回 1 hashMap.remove(2); // 删除键为2的数据 hashMap.get(2); // 返回 -1 (未找到) </pre> <p><br /> <strong>注意:</strong></p> <ul> <li>所有的值都在 <code>[1, 1000000]</code>的范围内。</li> <li>操作的总数目在<code>[1, 10000]</code>范围内。</li> <li>不要使用内建的哈希库。</li> </ul> ## 解法 <!-- 这里可写通用的实现逻辑 --> <!-- tabs:start --> ### **Python3** <!-- 这里可写当前语言的特殊实现逻辑 --> ```python ``` ### **Java** <!-- 这里可写当前语言的特殊实现逻辑 --> ```java ``` ### **...** ``` ``` <!-- tabs:end -->