- Table of contents
- Algorithms and Data Structures I
- Topics covered
- Assessment
- Module specification
- Syllabus
- Resources
This module will help you to develop your analytical and problem-solving skills. It will encourage you to think about how to use computers to solve problems. You'll develop skills in thinking algorithmically and learn the central concepts of algorithms and data structures. You will learn about linear data structures such as arrays, vectors and lists and a unifying framework for considering such data structures as collections. You'll study how algorithms can be expressed as flowcharts and pseudocode and how to convert these into programs. You'll learn specific algorithms used for sorting and searching, and how to express repetition as iteration and recursion. You will learn a simple model for execution of computation, and how to describe computational problems and their solutions. The model will allow you to compare algorithms regarding their correctness and regarding their efficiency.
- Introduction to algorithms, flowcharts and pseudocode
- Computations using flowcharts and pseudocode
- Pairs, vectors and dynamic arrays
- Basic searching
- Linked lists
- Basic sorting
- Advanced searching and introduction to complexity
- Recursive algorithms
- Advanced sorting
- Linear collections
One two hour unseen written examination and coursework (Type I)
- Algorithmic Design and Techniques - edX platform, by UC San Diego
- Data Structures Fundamentals - edX platform, by UC San Diego
- Easy Theory - "This is a channel about making Computer Science theory as easy as possible." Relevant for this course as well as Fundamentals of Computer Science.
-
Data Structures Visualization - Visualizations of a lot of data structures and related algorithms.
-
Animated DSA Visualization - Sorting algorithms, searching algorithms and many data structures beautifully visualized.
- Comparison of Algorithms - See time complexity at a glance for various popular algorithms.
- Data Structure & Algorithms Introduction - Sorting algorithms, data structures, tree data structure and more.
- 2.7.2. Merge Sort Algorithm - Abdul Bari
- Algorithm lecture 8 -- Merge sort algorithm, analysis and problems - Gate Lectures by Ravindrababu Ravula
- Algorithms lecture 9 -- Quick sort algorithm - Gate Lectures by Ravindrababu Ravula
- 2.8.1 QuickSort Algorithm - Abdul Bari
- 3. Insertion Sort, Merge Sort - MIT 6.006 Introduction to Algorithms, Fall 2011
- Big-O Cheat Sheet - bigocheatsheet.com
- Computational Complexity - MIT OpenCourseWare
- P vs. NP and the Computational Complexity Zoo - hackerdashery
"Specific essential readings for this course will be taken from the following text book:
- Cormen, T.H., C.E. Leierson, R.L. Rivest and C. Stein Introduction to Algorithms. (Cambridge, MA: MIT Press, 2009) 3rd edition.
The specific pages for the reading activities will be given in the platform, and there is no need to read beyond to recommended pages.
In addition to the text book, there are additional reading activities written by the course author, some of which involve coding exercises.
There will also be discussion prompts asking you to do some independent research using online sources."
- 2014, 2015, 2016, 2018, 2020: Visit this page.
- 🔒 [2020 written exam] enrolled students: more answers were compiled on Slack, see this thread)
- CLRS Solutions - Michelle Bodnar, Andrew Lohr