2012-10-23



Data Structures, Algorithms, and Applications in Java 

by

Sartaj Sahni 

 Download Slides:

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

Show more