博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Leetcode706.Design HashMap设计哈希映射
阅读量:5165 次
发布时间:2019-06-13

本文共 1180 字,大约阅读时间需要 3 分钟。

不使用任何内建的哈希表库设计一个哈希映射

具体地说,你的设计应该包含以下的功能

  • put(key, value):向哈希映射中插入(键,值)的数值对。如果键对应的值已经存在,更新这个值。
  • get(key):返回给定的键所对应的值,如果映射中不包含这个键,返回-1。
  • remove(key):如果映射中存在这个键,删除这个数值对。

 

示例:

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 (未找到)

 

注意:

  • 所有的值都在 [1, 1000000]的范围内。
  • 操作的总数目在[1, 10000]范围内。
  • 不要使用内建的哈希库。

 

老哥,说好的说有数都大于0呢??

 

class MyHashMap {private:    int hash[1000000 + 5] = {0};public:    /** Initialize your data structure here. */    MyHashMap() {        for(int i = 0; i < 1000000 + 5; i++)            hash[i] = -1;    }    /** value will always be positive. */    void put(int key, int value) {        hash[key] = value;    }    /** Returns the value to which the specified key is mapped, or -1 if this map contains no mapping for the key */    int get(int key) {        return hash[key];    }    /** Removes the mapping of the specified value key if this map contains a mapping for the key */    void remove(int key) {        hash[key] = -1;    }};

 

转载于:https://www.cnblogs.com/lMonster81/p/10433984.html

你可能感兴趣的文章
TYVJ-P1864 守卫者的挑战 题解
查看>>
【福利】论机房如何关闭方正软件保护卡
查看>>
Android自定义控件:动画类(六)----ValueAnimator高级进阶(一)
查看>>
五一放假作业4.30 用正则表达式写一个计算器!去掉括号,计算式子结果!
查看>>
51Nod1353 树
查看>>
Jzoj5455【NOIP2017提高A组冲刺11.6】拆网线
查看>>
Android 聊天室(一)
查看>>
web性能优化
查看>>
用SugarORM快速开发需要同步和保存大量数据的Android互联网客户端
查看>>
单实例和多实例的区别以及用途
查看>>
ETHREAD APC 《寒江独钓》内核学习笔记(4)
查看>>
Tensorflow做阅读理解与完形填空
查看>>
[RxJS] Stream Processing With RxJS vs Array Higher-Order Functions
查看>>
特定字符序列的判断(1028)
查看>>
记一次报错信息
查看>>
判断数组内是否有几个元素之和等于m
查看>>
ExtJS(三)Ext.MessageBox工具类举例
查看>>
条件、循环、函数定义 练习
查看>>
RestAssured接口自动化测试之基础方法
查看>>
华为面试
查看>>