Data Structures and Algorithms

(UOP-DBM4210.AE1)
Lessons
Lab
TestPrep
Get A Free Trial

Skills You’ll Get

1

Object Oriented Programming and Recursion

  • Goals, Principles, and Patterns
  • Software Development
  • Class Definitions
  • Inheritance
  • Namespaces and Object-Orientation
  • Shallow and Deep Copying
  • Illustrative Examples
  • Analyzing Recursive Algorithms
  • Recursion Run Amok
  • Further Examples of Recursion
  • Designing Recursive Algorithms
  • Eliminating Tail Recursion
  • Exercises
2

Array-Based Sequences, Stacks, Queues, and Deques, and Linked List

  • Python's Sequence Types
  • Low-Level Arrays
  • Dynamic Arrays and Amortization
  • Efficiency of Python's Sequence Types
  • Using Array-Based Sequences
  • Multidimensional Data Sets
  • Stacks
  • Queues
  • Double-Ended Queues
  • Singly Linked Lists
  • Circularly Linked Lists
  • Doubly Linked Lists
  • The Positional List ADT
  • Sorting a Positional List
  • Case Study: Maintaining Access Frequencies
  • Link-Based vs. Array-Based Sequences
  • Exercises
3

Trees, Priority Queues, Maps, Hash Tables, and Skip Lists

  • General Trees
  • Binary Trees
  • Implementing Trees
  • Tree Traversal Algorithms
  • Case Study: An Expression Tree
  • The Priority Queue Abstract Data Type
  • Implementing a Priority Queue
  • Heaps
  • Sorting with a Priority Queue
  • Adaptable Priority Queues
  • Maps and Dictionaries
  • Hash Tables
  • Sorted Maps
  • Skip Lists
  • Sets, Multisets, and Multimaps
  • Exercises
4

Search trees, Sorting, Selection, and Text Processing

  • Binary Search Trees
  • Balanced Search Trees
  • AVL Trees
  • Splay Trees
  • (2,4) Trees
  • Red-Black Trees
  • Why Study Sorting Algorithms?
  • Merge-Sort
  • Quick-Sort
  • Studying Sorting through an Algorithmic Lens
  • Comparing Sorting Algorithms
  • Python's Built-In Sorting Functions
  • Selection
  • Abundance of Digitized Text
  • Pattern-Matching Algorithms
  • Dynamic Programming
  • Text Compression and the Greedy Method
  • Tries
  • Exercises
5

Graph Algorithms, Memory Management and B-Trees

  • Graphs
  • Data Structures for Graphs
  • Graph Traversals
  • Transitive Closure
  • Directed Acyclic Graphs
  • Shortest Paths
  • Minimum Spanning Trees
  • Memory Management
  • Memory Hierarchies and Caching
  • External Searching and B-Trees
  • External-Memory Sorting
  • Exercises

1

Object Oriented Programming and Recursion

  • Understanding the init Method
  • Calculating the Product of Two Positive Integers
2

Array-Based Sequences, Stacks, Queues, and Deques, and Linked List

  • Implementing a Dynamic Array
  • Implementing a Stack
  • Implementing a Queue
3

Trees, Priority Queues, Maps, Hash Tables, and Skip Lists

  • Adding Elements to a Set
  • Performing Set Operations
4

Search trees, Sorting, Selection, and Text Processing

  • Using a Sorting Function
  • Performing Pattern Matching

Related Courses

All Courses
scroll to top