Data Structures, Algorithms, and Applications in Java

by

Sartaj Sahni


Powerpoint Presentations


Powerpoint presentations used in the lectures are available from this page. These presentations were prepared using Powerpoint 2000.

You may download a zip file that contains all 41 presentations by clicking here. Alternatively, you may download individual presentations from the table given below.

.
Lecture Content Reading Slides
1 Course overview and insertion sort. Chapters 1 through 3. Powerpoint
2 Insertion sort and practical complexities. Section 3.5. Powerpoint
3 Run-time measurement. Chapter 4. Powerpoint
4 Linear lists. Sections 5.1-5.2. Powerpoint
5 Array representation and array resizing. Section 5.3. Powerpoint
6 Walk through of code for ArrayLinearList. Section 5.3. Powerpoint
7 Iterators. Linked representation of a linear list. Sections 5.3 and 6.1. Powerpoint
8 Walk through of code for Chain. Head nodes, circular lists, doubly linked lists. Sections 6.2 and 6.3. Powerpoint
9 Simulated pointers and available-space lists. Sections 7.1 and 7.2.Powerpoint
10 Row-major and column-major indexing, and special matrices. Sections 8.1, 8.2, and 8.3. Powerpoint
11 Sparse matrices. Section 8.4. Powerpoint
12 Stacks--application to parentheses matching, towers-of-hanoi, railroad car rearrangement, and switchbox routing; array stacks. Sections 9.1, 9.2, 9.5. Powerpoint
13 Array and linked stacks. Section 9.3 and 9.4. Powerpoint
14 Nonapplicability of queues for parantheses matching, towers-of-hanoi, railroad problem with LIFO tracks, and switchbox routing. Application of queues to railroad problem with FIFO tracks, wire routing, and component labeling. Array and linked queues. Sections 10.1-10.4, 10.5.1-10.5.3. Powerpoint
15 Exam. - -
16 Dictionaries, linear list representation, and hashing. Sections 11.1, 11.2, 11.3, and 11.5. Powerpoint
17 Hashing and hash table design. Section 11.5. Powerpoint
18 LZW compression. Section 11.6. Powerpoint
19 Trees, binary trees, and properties. Sections 12.1-12.3. Powerpoint
20 Binary tree representation and operations. Sections 12.4 and 12.5. Powerpoint
21 Binary tree traversal methods-- preorder, inorder, postorder, level order. Reconstruction from two orders Sections 12.6-12.8. Powerpoint
22 Online equivalence classes. Section 12.9.2. Powerpoint
23 Application of priority queues to heap sort and machine scheduling. Min and max heaps. Sections 13.1-13.3, 13.6.1, and 13.6.2. Powerpoint
24 Initialization of min and max heaps. Height- and weight-biased leftist trees. Sections 13.4.4 and 13.5. Powerpoint
25 Winner and loser trees and application to k-way merging, run generation, and first-fit bin packing. Chapter 14. Powerpoint
26 Binary search trees and indexed binary search trees. Sections 15.1-15.5. Powerpoint
27 Definition of AVL trees. Graph applications and properties. Sections 16.1, 17.1-17.3. Powerpoint
28 Graph operations and representation. Sections 17.4-17.7. Powerpoint
29 Breadth-first and depth-first search. Application to path finding, connected components, and spanning trees. Sections 17.8 and 17.9. Powerpoint
30 Greedy method and application to bin packing, loading, and knapsack problems. Sections 18.1, 18.2, 18.3.1, and 18.3.2. Powerpoint
31 Exam. - -
32 Single source all destinations shortest paths algorithm. Section 18.3.5. Powerpoint
33 Kruskal's and Prim's minimum-cost spanning tree algorithms. Section 18.3.6. Powerpoint
34 Divide and conquer, and application to defective chessboard and min-max problem. Iterative min-max implementation. Sections 19.1 and 19.2.1. Powerpoint
35 Merge sort, natural merge sort, and quick sort. Sections 19.2.2 and 19.2.3. Powerpoint
36 Selection and closest pair of points. Sections 19.2.4 and 19.2.5. Powerpoint
37 Dynamic programming, 0/1 knapsack problem, recursive and iterative solutions. Sections 20.1 and 20.2.1. Powerpoint
38 Matrix multiplication chains, dynamic programming recurrence, recursive solution. Section 20.2.2. Powerpoint
39 Iterative solution to matrix multiplication chains. Section 20.2.2. Powerpoint
40 All pairs shortest paths. Section 20.2.3. Powerpoint
41 Single source shortest paths with negative edge weights. Section 20.2.4. Powerpoint
42 Solution space trees and backtracking. Section 21.1. Powerpoint
43 Branch and bound. Section 22.1. Powerpoint