Download presentation
Presentation is loading. Please wait.
1
CE 221 Data Structures and Algorithms
Chapter 5: Hashing Text: Read Weiss, § Izmir University of Economics
2
Izmir University of Economics
Introduction Search Tree ADT was disccussed. Now, Hash Table ADT Hashing is a technique used for performing insertions and deletions in constant average time. Thus, findMin, findMax and printAll are not supported. Izmir University of Economics
3
Izmir University of Economics
Tree Structures find, insert, delete worst case average case BST N log N AVL Izmir University of Economics
4
Izmir University of Economics
Goal Develop a structure that will allow users to insert / delete / find records in constant average time structure will be a table (relatively small) table completely contained in memory implemented by an array capitalizes on ability to access any element of the array in constant time Izmir University of Economics
5
Izmir University of Economics
Hash Function Determines position of a key in the array. Assume table (array) size is N (TableSize). Hash function hash(x) maps any key x to an int between 0 and N−1 For example, assume that N=15, that key x is a non-negative integer between 0 and MAX_INT, and hash function hash(x) = x % 15. Izmir University of Economics
6
Choosing the Hash Functions (1)
If keys are integers key % TableSize ex:all keys=10*i,TableSize=10 So, It’s a good idea to make TableSize a prime If keys are strings, then ASCII codes of chars % TableSize, when TableSize=10,007 and keys are at most 8 chars in length (127*8=1,016) The base 26+1=27 representation of the first 3 letters of the key (key[0] +27* key[1] + 729* key[2] ) % TableSize (263=17,576 but only 2,851 combinations in English) Izmir University of Economics
7
Choosing the Hash Functions (2)
Another hash function involving all characters compute this by Horner’s Rule Izmir University of Economics
8
Izmir University of Economics
Hash Function Let hash(x) = x % 15. Then, if x = f(x) = Storing the keys in the array is straightforward: _ _ _ _ _ _ _ _ _ Thus, delete and find can be done in O(1), and also insert, except… Izmir University of Economics
9
Izmir University of Economics
Hash Function What happens when you try to insert: x = 65 ? x = 65 hash(x) = 5 _ _ _ _ _ _ _ _ _ 65(?) If, when an element is inserted, it hashes to the same value as an already inserted element, this is called a collision. Izmir University of Economics
10
Izmir University of Economics
Handling Collisions Separate Chaining Open Addressing Linear Probing Quadratic Probing Double Hashing Izmir University of Economics
11
Izmir University of Economics
Handling Collisions Separate Chaining Izmir University of Economics
12
Izmir University of Economics
Separate Chaining Keep a list of elements that hash to the same value New elements can be inserted at the front of the list ex: x=i2 and hash(x)=x%10 Izmir University of Economics
13
Performance of Separate Chaining
Load factor of a hash table, λ λ = N/M (# of elements in the table/TableSize) So the average length of list is λ Search Time = Time to evaluate hash function + the time to traverse the list Unsuccessful search= λ nodes are examined Successful search=1 + ½* (N-1)/M (the node searched + half the expected # of other nodes) =1+1/2 *λ Observation: Table size is not important but load factor is. For separate chaining make λ 1 Izmir University of Economics
14
Separate Chaining: Disadvantages
Parts of the array might never be used. As chains get longer, search time increases to O(N) in the worst case. Constructing new chain nodes is relatively expensive (still constant time, but the constant is high). Is there a way to use the “unused” space in the array instead of using chains to make more space? Izmir University of Economics
15
Izmir University of Economics
Handling Collisions Open Addressing Izmir University of Economics
16
Izmir University of Economics
Handling Collisions Linear Probing An alternative to resolving collisions with linked lists is to try alternative cells until an empty cell is found. Alternative Cells are h0(x), h1(x), h2(x),... where hi(x)=(hash(x)+f(i)) % TableSize with f(0)=0, f is the collision resolution strategy. Because all the data go inside the table For Linear probing, λ < 0.5 Izmir University of Economics
17
Izmir University of Economics
Linear Probing In linear probing f(i)=i (Popular Choice) Let key x be stored in element hash(x)=t of the array 65(?) What do you do in case of a collision? If the hash table is not full, attempt to store key in the next array element (in this case (t+1)%N, (t+2)%N, (t+3)%N …) until you find an empty slot. Izmir University of Economics
18
Izmir University of Economics
Linear Probing Where do you store 65 ? attempts Izmir University of Economics
19
Linear Probing Performance (1)
If the table is relatively empty, blocks of occupied cells start forming (primary clustering) Expected # of probes for insertions and unsuccessful searches is ½(1+1/(1-λ)2) for successful searches is ½(1+1/(1-λ)) Izmir University of Economics
20
(earlier insertion are cheaper)
Linear Probing Performance (2) Assumptions: If clustering is not a problem, large table, probes are independent of each other Expected # of probes for unsuccessful searches (=expected # of probes until an empty cell is found) Expected # of probes for successful searches (=expected # of probes when an element was inserted) (=expected # of probes for an unsuccessful search) Average cost of an insertion (fraction of empty cells = 1 -λ) (earlier insertion are cheaper) Izmir University of Economics
21
Izmir University of Economics
Linear Probing Eliminates need for separate data structures (chains), and the cost of constructing nodes. Leads to problem of clustering. Elements tend to cluster in dense intervals in the array. Search efficiency problem remains. Deletion becomes trickier…. Izmir University of Economics
22
Deletion Problem -- SOLUTION
Standard deletion cannot be performed in a probing hash table, because the cell might have caused a collison to go past it. “Lazy” deletion Each cell is in one of 3 possible states: active empty deleted For Find or Delete only stop search when EMPTY state detected (not DELETED) Izmir University of Economics
23
Deletion-Aware Algorithms
Insert call Find, if cell = active already there if Cell = deleted or empty insert, cell = active Find cell empty NOT found cell deleted if key == key -> NOT FOUND else H = (H + 1) mod TS cell active if key == key -> FOUND Delete call Find, cell active DELETE; cell=deleted cell deleted NOT found Izmir University of Economics
24
Izmir University of Economics
Handling Collisions Quadratic Probing Izmir University of Economics
25
Izmir University of Economics
Quadratic Probing In quadratic probing f(i)=i2 (Popular Choice) Let key x be stored in element hash(x)=t of the array 65(?) What do you do in case of a collision? If the hash table is not full, attempt to store key in array elements (t+12)%N, (t+22)%N, (t+32)%N … until you find an empty slot. Izmir University of Economics
26
Izmir University of Economics
Quadratic Probing Where do you store 65 ? hash(65)=t=5 t t t t+9 attempts Izmir University of Economics
27
Izmir University of Economics
Quadratic Probing Theorem: If quadratic probing is used, and the table size is prime, then a new element can always be inserted if the table is at least half empty. Proof: Let TableSize be an odd prime > 3, -prove first alternative locations are all distinct. -Assume two of these locations are the same and Then, Since TableSize is prime and i and j are distinct (also less than floor(TableSize)), this is not possible. It follows that the first M/2 alternative are all distinct, and an insertion must succeed if the table is at least half full. Izmir University of Economics
28
Izmir University of Economics
Quadratic Probing Tends to distribute keys better than linear probing, alleviates the problem of clustering (primary clustering. There remains the problem of secondary clustering in which elements that hash to the same position will probe the same alternative cells Runs the risk of an infinite loop on insertion, unless precautions are taken. E.g., consider inserting the key 16 into a table of size 16, with positions 0, 1, 4 and 9 already occupied. Therefore, table size should be prime. Izmir University of Economics
29
Izmir University of Economics
Handling Collisions Double Hashing Izmir University of Economics
30
Izmir University of Economics
Double Hashing f(i)=i*hash2(x) is a popular choice hash2(x)should never evaluate to zero Now the increment is a function of the key The slots visited by the hash function will vary even if the initial slot was the same Avoids clustering Theoretically interesting, but in practice slower than quadratic probing, because of the need to evaluate a second hash function. Izmir University of Economics
31
Izmir University of Economics
Double Hashing Typical second hash function hash2(x)=R − ( x % R ) where R is a prime number, R < N Izmir University of Economics
32
Izmir University of Economics
Double Hashing Where do you store 99 ? hash(99)=t=9 Let hash2(x) = 11 − (x % 11), hash2(99)=d=11 Note: R=11, N=15 Attempt to store key in array elements (t+d)%N, (t+2d)%N, (t+3d)%N … Array: t t t t+33 attempts Where would you store: 127? Izmir University of Economics
33
Izmir University of Economics
Double Hashing Let f2(x)= 11 − (x % 11) hash2(127)=d=5 Array: t t t+5 attempts Infinite loop! Izmir University of Economics
34
Izmir University of Economics
Rehashing If the table gets too full, the running times for the operations will start taking too long. When the load factor exceeds a threshold, double the table size (smallest prime > 2 * old table size). Rehash each record in the old table into the new table. Expensive: O(N) work done in copying. However, if the threshold is large (e.g., ½), then we need to rehash only once per O(N) insertions, so the cost is “amortized” constant-time. Izmir University of Economics
35
Factors affecting efficiency
Choice of hash function Collision resolution strategy Load Factor Hashing offers excellent performance for insertion and retrieval of data. Izmir University of Economics
36
Comparison of Hash Table & BST
BST HashTable Average Speed O(log2N) O(1) Find Min/Max Yes No Items in a range Yes No Sorted Input Very Bad No problems Use HashTable if there is any suspicion of SORTED input & NO ordering information is required. Izmir University of Economics
37
Izmir University of Economics
Homework Assignments 5.1, 5.2, 5.12, 5.14 You are requested to study and solve the exercises. Note that these are for you to practice only. You are not to deliver the results to me. Izmir University of Economics
Similar presentations
© 2024 SlidePlayer.com. Inc.
All rights reserved.