890 likes | 927 Views
Join us for an interactive workshop focusing on innovative teaching methods for Data Structures. Explore active learning, discuss big ideas such as average case analysis, and engage in research discussions.
E N D
Data Structures Richard Anderson University of Washington IUCEE: Data Structures
Today’s topics • Teaching Data Structures • Active Learning in Data Structures • Big Ideas: Average Case Analysis • Research discussion IUCEE: Data Structures
Re-revised Workshop Schedule • Monday, June 30, Active learning and instructional goals • Morning • Welcome and Overview (1 hr) • Introductory Activity (1 hr). Determine background of participants • Active learning and instructional goals (1hr) in Discrete Math, Data Structures, Algorithms. • Afternoon • Group Work (1.5 hrs). Development of activities/goals from participant's classes. • Content lectures (Great Ideas in Computing): (1.5 hr) Problem mapping • Tuesday, July 1, Discrete Mathematics • Morning • Discrete Mathematics Teaching (2 hrs) • Activities in Discrete Mathematics (1 hr) • Afternoon • Educational Technology Lecture (1.5 hrs) • Content Lecture: (1.5 hrs) Complexity Theory • Wednesday, July 2, Data Structures • Morning • Data Structures Teaching (2hrs) • Data Structure Activities (1 hr) • Afternoon • Content Lecture: (1.5 hr) Average Case Analysis • Research Discussion • Thursday, July 3, Algorithms • Morning • Algorithms Teaching (2 hrs) • Algorithms Activities (1 hr) • Afternoon • Content Lecture (1.5 hrs) Algorithm implementation • Theory discussion (optional) / Visit Mysore • Friday, July 4, Topics • Morning • Lecture (1.5 hrs) Socially relevant computing • Faculty Presentations (1.5 hrs) • Afternoon • Follow up discussion with RJA (1.5 hrs) • Follow up discussion with Krishna IUCEE: Welcome and Overview
Thursday and Friday • Final presentations • Short presentations by groups • How will you take ideas from this workshop and implement them in a class next term • Create a few power point slides • Find time on Thursday to prepare talks • Presentations after coffee break Friday morning IUCEE: Welcome and Overview
Highlights from Day 2 IUCEE: Discrete Mathematics
University of Washington Course • Data Structures and Algorithm Analysis in Java 2nd Ed., Mark Allen Weiss • Ten week term • 3 lectures per week (50 minutes) • 1 quiz section • Midterm, Final CSE 326 Data Structures (4) Abstract data types and their implementations as data structures. Efficient of algorithms employing these data structures; asymptotic analyses. Dictionaries: balanced search trees, hashing. Priority queues: heaps. Disjoint sets with union, find. Graph algorithms: shortest path, minimum spanning tree, topological sort, search. Sorting. Prerequisite: CSE 321. IUCEE: Data Structures
Course overview • Background (3) • Heaps (4) • Trees (5) • Hashing (1) • Union Find (2) • Sorting (2) • Graphs (3) • Special Topics (4) IUCEE: Data Structures
Analyzing the course and content • What is the purpose of each unit? • Long term impact on students • What are the learning goals of each unit? • How are they evaluated • What strategies can be used to make material relevant and interesting? • How does the context impact the content IUCEE: Data Structures
Broader goals • Analysis of course content • How does this apply to the courses that you teach? • Reflect on challenges of your courses IUCEE: Data Structures
Overall course context • Discrete structures a pre-requisite • Students will have taken other majors classes • Students interested in the implementations side of the course • Graduates remember the course positively • Internal inconsistency in course offerings • Many different instructors teach the course • Some instructors take a different approach • Concern that the material is out of date • CS2 introduces some of the concepts covered in the course IUCEE: Data Structures
Background • Need to define the course • Asymptotic analysis – why constant factors don’t matter • ADTs – this is an old program structuring concept • Handling the interface with CS2 is tricky • Some variety in which course offering students had IUCEE: Data Structures
Class Overview • Introduction to many of the basic data structures used in computer software • Understand the data structures • Analyze the algorithms that use them • Know when to apply them • Practice design and analysis of data structures. • Practice using these data structures by writing programs. • Make the transformation from programmer to computer scientist IUCEE: Data Structures
Goals • You will understand • what the tools are for storing and processing common data types • which tools are appropriate for which need • So that you can • make good design choices as a developer, project manager, or system customer • You will be able to • Justifyyour design decisions via formal reasoning • Communicateideas about programs clearly and precisely IUCEE: Data Structures
Concepts vs. Mechanisms Abstract Pseudocode Algorithm A sequence of high-level, language independent operations, which may act upon an abstracted view of data. Abstract Data Type (ADT) A mathematical description of an object and the set of operations on the object. Concrete Specific programming language Program A sequence of operations in a specific programming language, which may act upon real data in the form of numbers, images, sound, etc. Data structure A specific way in which a program’s data is represented, which reflects the programmer’s design choices/goals. IUCEE: Data Structures
E D C B A A F B C D E F Second Example: Stack ADT • LIFO: Last In First Out • Stack operations • create • destroy • push • pop • top • is_empty IUCEE: Data Structures
Algorithm Analysis: Why? • Correctness: • Does the algorithm do what is intended. • Performance: • What is the running time of the algorithm. • How much storage does it consume. • Different algorithms may be correct • Which should I use? IUCEE: Data Structures
Asymptotic Analysis 4n 0.5 n log n 2^n --- n n log n = 2 n log n = n log n • Eliminate low order terms • 4n + 5 • 0.5 n log n + 2n + 7 • n3 + 2n + 3n • Eliminate coefficients • 4n • 0.5 n log n • n log n2 => Any base x log is equivalent to a base 2 log within a constant factor log_A B = log_x B ------------- log_x A log_x B = log_2 B ------------- log_2 x IUCEE: Data Structures
Definition of Order Notation • Upper bound: T(n) = O(f(n)) Big-O Exist positive constants c and n’ such that T(n) c f(n) for all n n’ • Lower bound:T(n) = (g(n)) Omega Exist positive constants c and n’ such that T(n) c g(n) for all n n’ • Tight bound: T(n) = (f(n)) Theta When both hold: T(n) = O(f(n)) T(n) = (f(n)) IUCEE: Data Structures
Order Notation: Example Wait, crossover point at 100, not 19? Point is- big_O captures the relationship – doesn’t tell you exactly where the crossover point is. If we pick c =1, then n0=100 100n2 + 1000 5 (n3 + 2n2) for all n 19 So f(n) O( g(n) ) IUCEE: Data Structures
Types of Analysis All of these can be applied to any analysis case Two orthogonal axes: • Bound Flavor • Upper bound (O, o) • Lower bound (, ) • Asymptotically tight () • Analysis Case • Worst Case (Adversary) • Average Case • Best Case • Amortized IUCEE: Data Structures
Heaps • Multiple heaps are introduced • Priority Queue • Leftist Heaps • Skew Heaps • Binomial Queues • Idea of Priority Queue is absolutely fundamental • Other concepts introduced with other flavors of heaps • e.g., d-heaps allow higher branching factor and tradeoffs in operation costs • Introducing other queues only makes sense if underlying concepts are emphasized IUCEE: Data Structures
Queues that Allow Line Jumping • Need a new ADT • Operations: Insert an Item, Remove the “Best” Item 6 2 15 23 12 18 45 3 7 insert deleteMin IUCEE: Data Structures
Priority Queue ADT • PQueue data : collection of data with priority • PQueue operations • insert • deleteMin • PQueue property: for two elements in the queue, x and y, if x has a lowerpriority value than y, x will be deleted before y IUCEE: Data Structures
1 2 3 6 4 5 8 9 10 11 12 Representing Complete Binary Trees in an Array A From node i: left child: right child: parent: B C 2 * i 7 F G D E (2 * i)+1 H I J K L └ i / 2┘ implicit (array) implementation: IUCEE: Data Structures
Heap Order Property Heap order property: For every non-root node X, the value in the parent of X is less than (or equal to) the value in X. This is the order for a MIN heap – could do the same for a max heap. 10 10 20 80 20 80 40 60 85 99 30 15 50 700 not a heap This is a PARTIAL order (diff than BST) For each node, its value is less than all of its descendants (no distinction between left and right) IUCEE: Data Structures
Insert: percolate up 10 Now insert 90. (no swaps, even though 99 is larger!) Now insert 7. 20 80 40 60 85 99 50 700 65 15 Optimization, bubble up an empty space to reduce # of swaps 10 15 80 40 20 85 99 50 700 65 60 IUCEE: Data Structures
More Priority Queue Operations • decreaseKey • given a pointer to an object in the queue, reduce its priority value Solution: change priority and ____________________________ • increaseKey • given a pointer to an object in the queue, increase its priority value Solution: change priority and _____________________________ percolateUp percolateDown Why do we need a pointer? Why not simply data value? It’s hard to find in a pQ IUCEE: Data Structures
A Solution: d-Heaps How does height compare to bin heap? (less) • Each node has d children • Still representable by array • Good choices for d: • (choose a power of two for efficiency) • fit one set of children in a cache line • fit one set of children on a memory page/disk block 1 3 7 2 4 8 5 12 11 10 6 9 12 1 3 7 2 4 8 5 12 11 10 6 9 IUCEE: Data Structures
Leftist Heap Properties • Heap-order property • parent’s priority value is to childrens’ priority values • result: minimum element is at the root • Leftist property • For every node x, npl(left(x)) npl(right(x)) • result: tree is at least as “heavy” on the left as the right No, no IUCEE: Data Structures
Merging Two Leftist Heaps • merge(T1,T2) returns one leftist heap containing all elements of the two (distinct) leftist heaps T1 and T2 done? Leftist property?npl(left(x)) npl(right(x)) merge T1 a a merge L1 R1 L1 R1 a < b T2 b b L2 R2 L2 R2 IUCEE: Data Structures
Yet Another Data Structure:Binomial Queues • Structural property • Forest of binomial trees with at mostone tree of any height • Order property • Each binomial tree has the heap-order property What’s a forest? What’s a binomial tree? IUCEE: Data Structures
Binomial Queue with n elements Binomial Q with n elements has a unique structural representation in terms of binomial trees! Write n in binary: n = 1101 (base 2) = 13 (base 10) 1 B3 1 B2 No B1 1 B0 IUCEE: Data Structures
Trees • Understanding binary trees and binary search trees is critical • Material may have been covered in CS2 • but I want students to really understand it • implementation assignment can really help • long term understanding of search and deletion • Concept of balanced trees (e.g. AVL) important • Details less so IUCEE: Data Structures
Data left pointer right pointer Binary Trees • Binary tree is • a root • left subtree (maybe empty) • right subtree (maybe empty) • Representation: A B C D E F G H I J IUCEE: Data Structures
Binary Search Tree Data Structure • Structural property • each node has 2 children • result: • storage is small • operations are simple • average depth is small • Order property • all keys in left subtree smallerthan root’s key • all keys in right subtree larger than root’s key • result: easy to find any given key • What must I know about what I store? 8 5 11 2 6 10 12 4 7 9 14 13 IUCEE: Data Structures
10 5 15 2 9 20 17 7 30 Find in BST, Recursive Node Find(Object key, Node root) { if (root == NULL) return NULL; if (key < root.key) return Find(key, root.left); else if (key > root.key) return Find(key, root.right); else return root; } Runtime: IUCEE: Data Structures
Non-lazy Deletion • Removing an item disrupts the tree structure. • Basic idea: find the node that is to be removed. Then “fix” the tree so that it is still a binary search tree. • Three cases: • node has no children (leaf node) • node has one child • node has two children IUCEE: Data Structures
Deletion – The Two Child Case 10 Delete(5) 5 20 2 9 30 7 • A value guaranteed to be • between the two subtrees! • succ from right subtree • - pred from left subtree What can we replace 5 with? IUCEE: Data Structures
Balanced BST Observation • BST: the shallower the better! • For a BST with n nodes • Average height is O(log n) • Worst case height is O(n) • Simple cases such as insert(1, 2, 3, ..., n)lead to the worst case scenario Solution: Require a Balance Condition that • ensures depth is O(log n) – strong enough! • is easy to maintain – not too strong! IUCEE: Data Structures
The AVL Tree Data Structure Structural properties • Binary tree property (0,1, or 2 children) • Heights of left and right subtrees of every nodediffer by at most 1 Result: Worst case depth of any node is: O(log n) Ordering property • Same as for BST 8 5 11 2 6 10 12 4 7 9 13 14 15 IUCEE: Data Structures
Double rotation in general h 0 a b Z c h W h h -1 X Y h-1 W < b <X < c < Y < a < Z c b a X Y Z W h-1 h h h IUCEE: Data Structures Height of tree before? Height of tree after? Effect on Ancestors?
Since you’re down there anyway, fix up a lot of deep nodes! The Splay Tree Idea 10 If you’re forced to make a really deep access: 17 5 2 9 3 IUCEE: Data Structures
TIme to access(conservative) CPU (has registers) 1 ns per instruction SRAM 8KB - 4MB Cache Cache 2-10 ns Main Memory DRAM up to 10GB Main Memory 40-100 ns Disk a few milliseconds (5-10 Million ns) many GB Disk IUCEE: Data Structures
3 7 12 21 Solution: B-Trees Keep things more balanced M = 7 • specialized M-ary search trees • Each node has (up to) M-1 keys: • subtree between two keys x and y containsleaves with valuesv such thatx v< y • Pick branching factor Msuch that each node takes one full {page, block}of memory x<3 3x<7 7x<12 12x<21 21x IUCEE: Data Structures
Range Queries • Think of a range query. • “Give me all customers aged 45-55.” • “Give me all accounts worth $5m to $15m” • Can be done in time ________. • What if we want both: • “Give me all customers aged 45-55 with accounts worth between $5m and $15m.” IUCEE: Data Structures
Nearest Neighbor Search i g h e y d f query b a c x Nearest neighbor is e. IUCEE: Data Structures
k-d Tree Construction k-d tree cell x s1 i g y y s8 h s2 s6 s4 e s6 y d f x y y y s5 s3 s4 s7 s8 s2 b s7 a a b x g c f h i c s5 s3 s1 x d e IUCEE: Data Structures
Hashing • Great idea – but the idea can be conveyed quickly • Implementation of hash tables less important than in the past • Programmers should use build in HashTable class IUCEE: Data Structures
Hash Tables hash table • Constant time accesses! • A hash table is an array of some fixed size, usually a prime number. • General idea: hash function: h(K) key space (e.g., integers, strings) TableSize –1 IUCEE: Data Structures
Collision Resolution Collision: when two keys map to the same location in the hash table. Two ways to resolve collisions: • Separate Chaining • Open Addressing (linear probing, quadratic probing, double hashing) IUCEE: Data Structures