Computer Science 361
Analysis and Design of Algorithms
September 2015

Lecture Notes

  1. Introduction and PRELIMINARIES
  2. The Growth of Functions
  3. Recurrences
  4. Data Structures
  5. Lists
  6. Graphs
  7. Trees
  8. Priority Queues
  9. Divide and Conquer Technique
  10. Transform and Conquer Technique
  11. Heaps and Heap Sort
  12. Bubble Sort
  13. Other Sorting Algorithms
  14. AVL Trees
  15. Decrease and Conquer Programming Technique
  16. Topological Sort
  17. Greedy Programming Technique
  18. Fractional Knapsack
  19. Huffman Encoding
  20. Minimum Spanning Trees
  21. Union of disjoint sets and finding the partition
  22. Single Source Shortest Path
  23. Dynamic Programming
  24. Dynamic Programming -- Transitive closure and other Graph algorithms
  25. Iterative Improvement
  26. Hash Tables
  27. Limitations of Algorithm Power
  28. P and NP
  29. Cheat Sheet PS PDF

Last modified:Friday June 10, 2016 at 07:54 am ADT
Cezar Câmpeanu