Implement Hash Map Using Primitive Types
A small coding test that I encountered today.
Question
Using only primitive types, implement a fixed-size hash map that associates string keys with arbitrary data object references (you don't need to copy the object). Your data structure should be optimized for algorithmic runtime and memory usage. You should not import any external libraries, and may not use primitive hash map or dictionary types in languages like Python or Ruby.
The solution should be delivered in one class (or your language's equivalent) that provides the following functions:
- constructor(size): return an instance of the class with pre-allocated space for the given number of objects.
- boolean set(key, value): stores the given key/value pair in the hash map. Returns a boolean value indicating success / failure of the operation.
- get(key): return the value associated with the given key, or null if no value is set.
- delete(key): delete the value associated with the given key, returning the value on success or null if the key has no value.
- float load(): return a float value representing the load factor (`(items in hash map)/(size of hash map)`) of the data structure. Since the size of the dat structure is fixed, this should never be greater than 1.
If your language provides a built-in hashing function for strings (ex. `hashCode` in Java or `__hash__` in Python) you are welcome to use that. If not, you are welcome to do something naive, or use something you find online with proper attribution.
Solution
Key to construct a hash map is to construct several key-value entries.
package datastructures.map;
public class MyEntry<K, V> {
private final K key;
private V value;
public MyEntry(K key, V value) {
this.key = key;
this.value = value;
}
public K getKey() {
return key;
}
public V getValue() {
return value;
}
public void setValue(V value) {
this.value = value;
}
}
package datastructures.map;
// import datastructures.map.MyEntry;
public class MyMap<K, V> {
private int fullSize;
private int size;
private int DEFAULT_CAPACITY = 16;
private MyEntry<K, V>[] map = new MyEntry[DEFAULT_CAPACITY];
public MyMap(int size) {
this.size = 0;
this.map = new MyEntry[size];
this.fullSize = size;
}
public V get(K key) {
for (int i = 0; i < size; i++) {
if (map[i].getKey().equals(key)) {
return map[i].getValue();
}
}
return null;
}
public boolean set(K key, V value) {
boolean insert = true;
for (int i = 0; i < size; i++) {
if (map[i].getKey().equals(key)) {
map[i].setValue(value);
insert = false;
}
}
if (insert) {
if (size >= fullSize) {
return false;
}
else {
map[size] = new MyEntry(key, value);
size++;
}
}
return true;
}
public V delete(K key) {
for (int i = 0; i < size; i++) {
if (map[i].getKey().equals(key)) {
V value = map[i].getValue();
map[i] = null;
condenseArray(i);
return value;
}
}
return null;
}
public float load() {
return (float)size / (float)fullSize;
}
private void condenseArray(int start) {
size--;
for (int i = start; i < size; i++) {
map[i] = map[i + 1];
}
}
}
package datastructures.map;
public class Test {
public static void main(String[] args) {
int size = 8;
MyMap<Character, Integer> test = new MyMap<Character, Integer>(size);
test.set('a', 1);
test.set('b', 2);
test.set('c', 3);
test.set('d', 4);
System.out.println(test.get('a'));
System.out.println(test.set('a', 2));
System.out.println(test.get('a'));
System.out.println(test.load());
test.delete('b');
System.out.println(test.load());
}
}
More basic knowledge about Java
Package and Import
Classes under same package need not import each other.
Here, we set three classes in package datastructures.map, and my current path is /home/Desktop
Then, I need to make a directory of datastructures/map under Desktop and put three source codes in that directory.
Meanwhile, I need to compile under Desktop directory.
To compile the Java programs with package statements you have to do use -d option as shown below.
javac -d Destination_folder file_name.java
There can be only one package statement in each source file, and it applies to all types in the file.
Two major results occur when a class is placed in a package:
1. The name of the package becomes a part of the name of the class, as we just discussed in the previous section.
2. The name of the package must match the directory structure where the corresponding bytecode resides.
Constructor
Constructor for object should not include inner types.
For example
public MyMap<K, V>() {} is wrong!
public MyMap() {} is right!
Public Class
(referrence: Tutorialspoint)
Four access level for classes:
1. Visible to the package. the default. No modifiers are needed.
2. Visible to the class only (private).
3. Visible to the world (public).
4. Visible to the package and all subclasses (protected).
Access Control and Inheritance:
1. Methods declared public in a superclass also must be public in all subclasses.
2. Methods declared protected in a superclass must either be protected or public in subclasses; they cannot be private.
3. Methods declared without access control (no modifier was used) can be declared more private in subclasses.
4. Methods declared private are not inherited at all, so there is no rule for them.
Implement Hash Map Using Primitive Types的更多相关文章
- Hash Map (Hash Table)
Reference: Wiki PrincetonAlgorithm What is Hash Table Hash table (hash map) is a data structure use ...
- Java中的原始类型(Primitive Types)与引用类型(Reference Values)
Java虚拟机可以处理的类型有两种,一种是原始类型(Primitive Types),一种是引用类型(Reference Types). 与之对应,也存在有原始值(Primitive Values)和 ...
- Effective Java 49 Prefer primitive types to boxed primitives
No. Primitives Boxed Primitives 1 Have their own values Have identities distinct from their values 2 ...
- How to Map Distinct Value Types Using Java Generics--reference
原文:http://www.codeaffine.com/2015/03/04/map-distinct-value-types-using-java-generics/ Occasionally t ...
- hdu1381 Crazy Search(hash map)
题目意思: 给出一个字符串和字串的长度,求出该字符串的全部给定长度的字串的个数(不同样). 题目分析: 此题为简单的字符串哈hash map问题,能够直接调用STL里的map类. map<str ...
- C# 01 Primitive Types and Expressions
Class Data or Attributes state of the application Methods or Functions have behavior Namespace is a ...
- [LeetCode] Repeated DNA Sequences hash map
All DNA is composed of a series of nucleotides abbreviated as A, C, G, and T, for example: "ACG ...
- Hash Map 在java中的解释及示例
目录 HashMap在java中的应用及示例 HashMap的内部结构 HashMap的性能 同步HashMap HashMap的构造函数 HashMap的时间复杂度 HashMap的方法 1. vo ...
- Redis的增删改查 c# key value类型和hash map 类型
using Newtonsoft.Json; using StackExchange.Redis; using System; using System.Collections.Generic; us ...
随机推荐
- 【剑指offer】面试题31:连续子数组的最大和
题目: 在古老的一维模式识别中,常常需要计算连续子向量的最大和,当向量全为正数的时候,问题很好解决.但是,如果向量中包含负数,是否应该包含某个负数,并期望旁边的正数会弥补它呢?例如:{6,-3,-2, ...
- Unity 弹道轨迹
using UnityEngine; using System.Collections; public class ProjectileTest : MonoBehaviour { public Ga ...
- JSP错题纠错
A:判断学员是否手动安装过Tomcat(练习熟练度) B:使学员了解Tomcat的运行过程 ,浏览器向Web服务器发送请求,Web站点处理请求后,把处理后的结果响应给浏览器 C:Tomcat作为Web ...
- 在多线程环境中使用Jedis
Jedis是一个Java语言的Redis客户端,它为Java语言连接与操作Redis提供了简单易用的接口. Jedis不是线程安全的.故不应该在多线程环境中共用一个Jedis实例.可是.也应该避免直接 ...
- 针对各主流数据mysql、sqlserver、oracle中文乱码问题。
针对各主流数据mysql.sqlserver.oracle当以编码格式gbk存放数据时,要注意字符串类型的字段,要采用宽字符串nvarchar存放,前提是当你的应用程序是utf8编码,而数据库是gbk ...
- [Ext JS 4] 实战之Grid, Tree Gird编辑Cell
前言 本篇这里以稍微复杂一点的Tree Grid 来介绍. 在写编辑grid 之, 先来看一下 grid 的 selType 的配置. 先给一个简单的Tree grid 的例子: Ext.onRead ...
- C++模板 静态成员 定义(实例化)
问一个问题: 考虑一个模板: template <typename T> class Test{ public: static std::string info; }; 对于下面若干种定义 ...
- iOS绘图教程
本文是<Programming iOS5>中Drawing一章的翻译,考虑到主题完整性,翻译版本中加入了一些书中未涉及到的内容.希望本文能够对你有所帮助.(本文由海水的味道翻译整理,转载请 ...
- IoC容器Autofac之IOC/DI基本概念(二)
原文:http://www.cnblogs.com/xdp-gacl/p/4249939.html 1.1.IoC是什么 Ioc—Inversion of Control,即“控制反转”,一种设计思想 ...
- sqlite3---代码操作
1.创建数据库 NSString * docPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainM ...