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.

Tutorialspoint

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的更多相关文章

  1. Hash Map (Hash Table)

    Reference: Wiki  PrincetonAlgorithm What is Hash Table Hash table (hash map) is a data structure use ...

  2. Java中的原始类型(Primitive Types)与引用类型(Reference Values)

    Java虚拟机可以处理的类型有两种,一种是原始类型(Primitive Types),一种是引用类型(Reference Types). 与之对应,也存在有原始值(Primitive Values)和 ...

  3. 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 ...

  4. 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 ...

  5. hdu1381 Crazy Search(hash map)

    题目意思: 给出一个字符串和字串的长度,求出该字符串的全部给定长度的字串的个数(不同样). 题目分析: 此题为简单的字符串哈hash map问题,能够直接调用STL里的map类. map<str ...

  6. C# 01 Primitive Types and Expressions

    Class Data or Attributes state of the application Methods or Functions have behavior Namespace is a ...

  7. [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 ...

  8. Hash Map 在java中的解释及示例

    目录 HashMap在java中的应用及示例 HashMap的内部结构 HashMap的性能 同步HashMap HashMap的构造函数 HashMap的时间复杂度 HashMap的方法 1. vo ...

  9. Redis的增删改查 c# key value类型和hash map 类型

    using Newtonsoft.Json; using StackExchange.Redis; using System; using System.Collections.Generic; us ...

随机推荐

  1. libeXosip2(1) -- Modules

    Modules Here is a list of all modules: [detail level 12] The eXtented eXosip stack LibeXosip2 Versio ...

  2. poj3299

                                                                                                         ...

  3. iOS 3DES加密 和 java 3DES 解密

    首先进入头文件: #import <CommonCrypto/CommonDigest.h> #import <CommonCrypto/CommonCryptor.h> #i ...

  4. mycat实例(2)

    全局序列号 数据切分后,原有的关系数据库中的主键约束在分布式条件下将无法使用,因此需要引入外部机制保证数据唯一性标识,这种保证全局性的数据唯一标识的机制就是全局序列号(sequence). 1. 本地 ...

  5. ArcEngine颜色可视化

    AE中利用.NET中的ColorDialog对话框,将color对象转化为ArcEngine中的IRgbColor (1)在实现颜色选择之前,需定义这两种颜色之间的转换函数 //Color转换为Rgb ...

  6. JavaScript ----------------- 原型式继承

    思想:借助原型可以基于已有的对象创建新对象,同时还不必因此创建自定义类型.为了达到这个目的,看看下面的实现方式 function object(o){ function F(){ } F.protot ...

  7. JS软键盘代码

    页面代码如下: <HTML> <HEAD> <TITLE>一个不错的js软键盘代码</TITLE> <meta http-equiv=" ...

  8. Android布局自定义Shap圆形ImageView,可以单独设置背景与图片

    一.图片预览:                  一.实现功能: 需求要实现布局中为圆形图片,图片背景与图标分开且合并到一个ImageView. 二.具体实现: XML中布局中定义ImageView, ...

  9. JSP基础学习(二)

    1.JSP页面的内容组成 静态部分:标准的HTML标签.静态的页面内容,这些内容与静态的HTML页面相同 动态部分:这些由java程序来动态生成 2.<% out.println(new jav ...

  10. C#图像处理(1):在图片上加文字和改变文字的方向

    C#在图片上加文字,代码如下: /// <summary> /// 图片上方加文字,文字将会被180度反转 /// </summary> /// <param name= ...