1 / 31

ITCS 6114

ITCS 6114. Skip Lists Hashing. Red-Black Trees. Red-black trees do what they do very well What do you think is the worst thing about red-black trees? A: coding them up. David Luebke 2 12/21/2019. Skip Lists. A relatively recent data structure

lfrank
Download Presentation

ITCS 6114

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. ITCS 6114 Skip Lists Hashing David Luebke 112/21/2019

  2. Red-Black Trees • Red-black trees do what they do very well • What do you think is the worst thing about red-black trees? • A: coding them up David Luebke 212/21/2019 David Luebke 212/21/2019

  3. Skip Lists • A relatively recent data structure • “A probabilistic alternative to balanced trees” • A randomized algorithm with benefits of r-b trees • O(lg n) expected time for Search, Insert • O(1) time for Min, Max, Succ, Pred • Much easier to code than r-b trees • Fast! David Luebke 312/21/2019 David Luebke 312/21/2019

  4. So these all take O(1)time in a linked list. Can you think of a wayto do these in O(1) timein a red-black tree? Goal: make these O(lg n) time in a linked-list setting Linked Lists • Think about a linked list as a structure for dynamic sets. What is the running time of: • Min() and Max()? • Successor()? • Delete()? • How can we make this O(1)? • Predecessor()? • Search()? • Insert()? David Luebke 412/21/2019 David Luebke 412/21/2019

  5. level 3 level 2 3 9 12 18 29 35 37 Skip Lists • The basic idea: • Keep a doubly-linked list of elements • Min, max, successor, predecessor: O(1) time • Delete is O(1) time, Insert is O(1)+Search time • During insert, add each level-i element to level i+1 with probability p (e.g., p = 1/2 or p = 1/4) level 1 David Luebke 512/21/2019

  6. Skip List Search • To search for an element with a given key: • Find location in top list • Top list has O(1) elements with high probability • Location in this list defines a range of items in next list • Drop down a level and recurse • O(1) time per level on average • O(lg n) levels with high probability • Total time: O(lg n) David Luebke 612/21/2019

  7. Skip List Insert • Skip list insert: analysis • Do a search for that key • Insert element in bottom-level list • With probability p, recurse to insert in next level • Expected number of lists = 1+ p + p2 + … = ??? = 1/(1-p) = O(1) if p is constant • Total time = Search + O(1) = O(lg n) expected • Skip list delete: O(1) David Luebke 712/21/2019

  8. Skip Lists • O(1) expected time for most operations • O(lg n) expected time for insert • O(n2) time worst case (Why?) • But random, so no particular order of insertion evokes worst-case behavior • O(n) expected storage requirements (Why?) • Easy to code David Luebke 812/21/2019

  9. Review: Hashing Tables • Motivation: symbol tables • A compiler uses a symbol table to relate symbols to associated data • Symbols: variable names, procedure names, etc. • Associated data: memory location, call graph, etc. • For a symbol table (also called a dictionary), we care about search, insertion, and deletion • We typically don’t care about sorted order David Luebke 912/21/2019

  10. Review: Hash Tables • More formally: • Given a table T and a record x, with key (= symbol) and satellite data, we need to support: • Insert (T, x) • Delete (T, x) • Search(T, x) • We want these to be fast, but don’t care about sorting the records • The structure we will use is a hash table • Supports all the above in O(1) expected time! David Luebke 1012/21/2019

  11. Hashing: Keys • In the following discussions we will consider all keys to be (possibly large) natural numbers • How can we convert floats to natural numbers for hashing purposes? • How can we convert ASCII strings to natural numbers for hashing purposes? David Luebke 1112/21/2019

  12. Review: Direct Addressing • Suppose: • The range of keys is 0..m-1 • Keys are distinct • The idea: • Set up an array T[0..m-1] in which • T[i] = x if x T and key[x] = i • T[i] = NULL otherwise • This is called a direct-address table • Operations take O(1) time! • So what’s the problem? David Luebke 1212/21/2019

  13. The Problem With Direct Addressing • Direct addressing works well when the range m of keys is relatively small • But what if the keys are 32-bit integers? • Problem 1: direct-address table will have 232 entries, more than 4 billion • Problem 2: even if memory is not an issue, the time to initialize the elements to NULL may be • Solution: map keys to smaller range 0..m-1 • This mapping is called a hash function David Luebke 1312/21/2019

  14. Hash Functions • Next problem: collision T 0 U(universe of keys) h(k1) k1 h(k4) k4 K(actualkeys) k5 h(k2) = h(k5) k2 h(k3) k3 m - 1 David Luebke 1412/21/2019 David Luebke 1412/21/2019

  15. Resolving Collisions • How can we solve the problem of collisions? • Solution 1: chaining • Solution 2: open addressing David Luebke 1512/21/2019 David Luebke 1512/21/2019

  16. Open Addressing • Basic idea (details in Section 12.4): • To insert: if slot is full, try another slot, …, until an open slot is found (probing) • To search, follow same sequence of probes as would be used when inserting the element • If reach element with correct key, return it • If reach a NULL pointer, element is not in table • Good for fixed sets (adding but no deletion) • Example: spell checking • Table needn’t be much bigger than n David Luebke 1612/21/2019 David Luebke 1612/21/2019

  17. Chaining • Chaining puts elements that hash to the same slot in a linked list: T —— U(universe of keys) k1 k4 —— —— k1 —— k4 K(actualkeys) k5 —— k7 k5 k2 k7 —— —— k3 k2 k3 —— k8 k6 k8 k6 —— —— David Luebke 1712/21/2019 David Luebke 1712/21/2019

  18. Chaining • How do we insert an element? T —— U(universe of keys) k1 k4 —— —— k1 —— k4 K(actualkeys) k5 —— k7 k5 k2 k7 —— —— k3 k2 k3 —— k8 k6 k8 k6 —— —— David Luebke 1812/21/2019 David Luebke 1812/21/2019

  19. Chaining • How do we delete an element? • Do we need a doubly-linked list for efficient delete? T —— U(universe of keys) k1 k4 —— —— k1 —— k4 K(actualkeys) k5 —— k7 k5 k2 k7 —— —— k3 k2 k3 —— k8 k6 k8 k6 —— —— David Luebke 1912/21/2019 David Luebke 1912/21/2019

  20. Chaining • How do we search for a element with a given key? T —— U(universe of keys) k1 k4 —— —— k1 —— k4 K(actualkeys) k5 —— k7 k5 k2 k7 —— —— k3 k2 k3 —— k8 k6 k8 k6 —— —— David Luebke 2012/21/2019 David Luebke 2012/21/2019

  21. Analysis of Chaining • Assume simple uniform hashing: each key in table is equally likely to be hashed to any slot • Given n keys and m slots in the table: the load factor = n/m = average # keys per slot • What will be the average cost of an unsuccessful search for a key? David Luebke 2112/21/2019 David Luebke 2112/21/2019

  22. Analysis of Chaining • Assume simple uniform hashing: each key in table is equally likely to be hashed to any slot • Given n keys and m slots in the table, the load factor = n/m = average # keys per slot • What will be the average cost of an unsuccessful search for a key? A: O(1+) David Luebke 2212/21/2019 David Luebke 2212/21/2019

  23. Analysis of Chaining • Assume simple uniform hashing: each key in table is equally likely to be hashed to any slot • Given n keys and m slots in the table, the load factor = n/m = average # keys per slot • What will be the average cost of an unsuccessful search for a key? A: O(1+) • What will be the average cost of a successful search? David Luebke 2312/21/2019 David Luebke 2312/21/2019

  24. Analysis of Chaining • Assume simple uniform hashing: each key in table is equally likely to be hashed to any slot • Given n keys and m slots in the table, the load factor = n/m = average # keys per slot • What will be the average cost of an unsuccessful search for a key? A: O(1+) • What will be the average cost of a successful search? A: O(1 +/2) = O(1 + ) David Luebke 2412/21/2019 David Luebke 2412/21/2019

  25. Analysis of Chaining Continued • So the cost of searching = O(1 + ) • If the number of keys n is proportional to the number of slots in the table, what is ? • A:  = O(1) • In other words, we can make the expected cost of searching constant if we make  constant David Luebke 2512/21/2019 David Luebke 2512/21/2019

  26. Choosing A Hash Function • Clearly choosing the hash function well is crucial • What will a worst-case hash function do? • What will be the time to search in this case? • What are desirable features of the hash function? • Should distribute keys uniformly into slots • Should not depend on patterns in the data David Luebke 2612/21/2019 David Luebke 2612/21/2019

  27. Hash Functions:The Division Method • h(k) = k mod m • In words: hash k into a table with m slots using the slot given by the remainder of k divided by m • What happens to elements with adjacent values of k? • What happens if m is a power of 2 (say 2P)? • What if m is a power of 10? • Upshot: pick table size m = prime number not too close to a power of 2 (or 10) David Luebke 2712/21/2019 David Luebke 2712/21/2019

  28. What does this term represent? Hash Functions:The Multiplication Method • For a constant A, 0 < A < 1: • h(k) =  m (kA - kA)  David Luebke 2812/21/2019 David Luebke 2812/21/2019

  29. Hash Functions:The Multiplication Method • For a constant A, 0 < A < 1: • h(k) =  m (kA - kA)  • Choose m = 2P • Choose A not too close to 0 or 1 • Knuth: Good choice for A = (5 - 1)/2 Fractional part of kA David Luebke 2912/21/2019 David Luebke 2912/21/2019

  30. Hash Functions: Worst Case Scenario • Scenario: • You are given an assignment to implement hashing • You will self-grade in pairs, testing and grading your partner’s implementation • In a blatant violation of the honor code, your partner: • Analyzes your hash function • Picks a sequence of “worst-case” keys, causing your implementation to take O(n) time to search • What’s an honest CS student to do? David Luebke 3012/21/2019 David Luebke 3012/21/2019

  31. Hash Functions: Universal Hashing • As before, when attempting to foil an malicious adversary: randomize the algorithm • Universal hashing: pick a hash function randomly in a way that is independent of the keys that are actually going to be stored • Guarantees good performance on average, no matter what keys adversary chooses David Luebke 3112/21/2019 David Luebke 3112/21/2019

More Related