Skip to content

Commit 07d2b09

Browse files
committed
Create PearsonHashing.java
1 parent 656b39e commit 07d2b09

2 files changed

Lines changed: 52 additions & 1 deletion

File tree

Lines changed: 50 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,50 @@
1+
/**
2+
* Hash function designed for fast execution on processors with 8-bit registers.
3+
*
4+
* @author Atom
5+
* @see <a href="https://en.wikipedia.org/wiki/Pearson_hashing">Pearson hashing</a>
6+
* @see <a href="https://tools.ietf.org/html/rfc3074">RFC3074</a>
7+
*/
8+
public class PearsonHashing {
9+
10+
// A "mixing table" of 256 distinct values, in pseudo-random order.
11+
// RFC3074 https://tools.ietf.org/html/rfc3074
12+
private static final char[] mixingTable = {
13+
251, 175, 119, 215, 81, 14, 79, 191, 103, 49, 181, 143, 186, 157, 0,
14+
232, 31, 32, 55, 60, 152, 58, 17, 237, 174, 70, 160, 144, 220, 90, 57,
15+
223, 59, 3, 18, 140, 111, 166, 203, 196, 134, 243, 124, 95, 222, 179,
16+
197, 65, 180, 48, 36, 15, 107, 46, 233, 130, 165, 30, 123, 161, 209, 23,
17+
97, 16, 40, 91, 219, 61, 100, 10, 210, 109, 250, 127, 22, 138, 29, 108,
18+
244, 67, 207, 9, 178, 204, 74, 98, 126, 249, 167, 116, 34, 77, 193,
19+
200, 121, 5, 20, 113, 71, 35, 128, 13, 182, 94, 25, 226, 227, 199, 75,
20+
27, 41, 245, 230, 224, 43, 225, 177, 26, 155, 150, 212, 142, 218, 115,
21+
241, 73, 88, 105, 39, 114, 62, 255, 192, 201, 145, 214, 168, 158, 221,
22+
148, 154, 122, 12, 84, 82, 163, 44, 139, 228, 236, 205, 242, 217, 11,
23+
187, 146, 159, 64, 86, 239, 195, 42, 106, 198, 118, 112, 184, 172, 87,
24+
2, 173, 117, 176, 229, 247, 253, 137, 185, 99, 164, 102, 147, 45, 66,
25+
231, 52, 141, 211, 194, 206, 246, 238, 56, 110, 78, 248, 63, 240, 189,
26+
93, 92, 51, 53, 183, 19, 171, 72, 50, 33, 104, 101, 69, 8, 252, 83, 120,
27+
76, 135, 85, 54, 202, 125, 188, 213, 96, 235, 136, 208, 162, 129, 190,
28+
132, 156, 38, 47, 1, 7, 254, 24, 4, 216, 131, 89, 21, 28, 133, 37, 153,
29+
149, 80, 170, 68, 6, 169, 234, 151
30+
};
31+
32+
public static byte hash(String message) {
33+
char hash = 0;
34+
for (int i = 0; i < message.length(); i++) {
35+
char c = message.charAt(i);
36+
int index = (hash ^ c) & 0x0FF;
37+
hash = mixingTable[index];
38+
}
39+
return (byte) hash;
40+
}
41+
42+
public static void main(String[] args) {
43+
System.out.println(String.format("0x%02X", hash("hello")));
44+
System.out.println(String.format("0x%02X", hash("world")));
45+
System.out.println(String.format("0x%02X", hash("hello, world!")));
46+
System.out.println(String.format("0x%02X", hash("Hello, World!")));
47+
System.out.println(String.format("0x%02X", hash("H€llo, World!")));
48+
}
49+
50+
}

README.md

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -42,6 +42,7 @@ LongestPath | | | | | :+1: | | | |
4242
MergeSort | :+1: | :+1: | | :+1: | :+1: | :+1: | :+1: | |
4343
MiniMaxWithABPruning | :+1: | | | | | | | |
4444
Modified_Binary_Search | | | | :+1: | | | | |
45+
Pearson Hasing | :+1: | | | | | | | |
4546
Postman Sort | | | | :+1: | | | | |
4647
Quick Sort | :+1: | :+1: | | | | :+1: | :+1: | :+1: | :+1:
4748
Quick Select | :+1: | :+1: | | | | | :+1: | |
@@ -569,7 +570,7 @@ Union Find |:+1:| | | | | | | |
569570

570571
* Paxos algorithm : a family of protocols for solving consensus in a network of unreliable processors
571572

572-
* Pearson hashing : computes 8 bit value only, optimized for 8 bit computers
573+
* [Pearson hashing](PearsonHashing) : computes 8 bit value only, optimized for 8 bit computers
573574

574575
* Perceptron : the simplest kind of feedforward neural network: a linear classifier.
575576

0 commit comments

Comments
 (0)