| 
 Undergraduate Course: Algorithms and Data Structures (INFR10052)
Course Outline
| School | School of Informatics | College | College of Science and Engineering |  
| Credit level (Normal year taken) | SCQF Level 10 (Year 3 Undergraduate) | Availability | Available to all students |  
| SCQF Credits | 10 | ECTS Credits | 5 |  
 
| Summary | The course aims to provide general techniques for the design of efficient algorithms and, in parallel, develop appropriate mathematical tools for analysing their performance. In this, it broadens and deepens the study of algorithms and data structures initiated in INF2. The focus is on algorithms, more than data structures. Along the way, problem solving skills are exercised and developed. |  
| Course description | Introductory concepts Review of CS2. Models of computation; time and space complexity; upper and lower bounds, big-O and big-Omega notation; average and worst case analysis.
 
 Divide and conquer
 Matrix multiplication: Strassen's algorithm; the discrete Fourier transform (DFT), the fast Fourier transform (FFT). Expressing the runtime of a recursive algorithm as a recurrence relation; solving recurrence relations.
 
 Sorting
 Quicksort and its analysis; worst-case, best-case and average-case.
 
 Data structures: Disjoint sets
 The "disjoint sets'' (union-find) abstract data type: specification and implementations as lists and trees. Union-by-rank, path-compression, etc., "heuristics''. Applications to finding minimum spanning trees.
 
 Dynamic programming
 Introduction to the technique; examples: Matrix-chain multiplication, Longest common subsequences.
 
 Graph/Network algorithms
 Network flow, Max-flow/min-cut theorem, Ford-Fulkerson algorithm.
 
 Geometric algorithms
 Convex hull of a set of points (in 2-d).
 
 Relevant QAA Computing Curriculum Sections: Data Structures and Algorithms
 |  
Entry Requirements (not applicable to Visiting Students)
| Pre-requisites | Students MUST have passed:    
Informatics 2 - Introduction to Algorithms and Data Structures (INFR08026) OR   
Discrete Mathematics and Probability (INFR08031) 
 | Co-requisites |  |  
| Prohibited Combinations |  | Other requirements | Students who took different second-year Maths courses should get permission of the Course organiser (lecturer). 
 MSc students should have taken an introductory algorithms course and mathematics covering the material below, and should get  permission from the Course organiser (lecturer).
 
 This course has the following mathematics prerequisites:
 1 - Calculus: limits, sums, integration, differentiation, recurrence relations, the Master theorem.
 2 - Graph theory: graphs, digraphs, components, trees, weighted graphs, DFS, BFS.
 3 - Probability: random variables, expectation, variance, Markov's inequality, Chebychev's inequality
 4 - Linear algebra: vectors, matrices, matrix multiplication, scalar products.
 5 - Complex numbers: the imaginary unit i, addition and multiplication in C, exponentiation.
 6 - Generalities: induction, O-notation, proof by contradiction, confidence in proving theorems.
 |  
Information for Visiting Students 
| Pre-requisites | Visiting students are required to have comparable background to that assumed by the course prerequisites listed in the Degree Regulations & Programmes of Study. If in doubt, consult the Course organiser (lecturer). |  
		| High Demand Course? | Yes |  
Course Delivery Information
|  |  
| Academic year 2025/26, Available to all students (SV1) | Quota:  None |  | Course Start | Semester 1 |  Timetable | Timetable | 
| Learning and Teaching activities (Further Info) | Total Hours:
100
(
 Lecture Hours 20,
 Seminar/Tutorial Hours 8,
 Dissertation/Project Supervision Hours 2,
 Supervised Practical/Workshop/Studio Hours 2,
 Programme Level Learning and Teaching Hours 2,
Directed Learning and Independent Learning Hours
66 ) |  
| Assessment (Further Info) | Written Exam
75 %,
Coursework
25 %,
Practical Exam
0 % |  
| Feedback | Not entered |  
| Exam Information |  
    | Exam Diet | Paper Name | Minutes |  |  
| Main Exam Diet S1 (December) | Algorithms and Data Structures (INFR10052) | 120 |  |  
 
Learning Outcomes 
| On completion of this course, the student will be able to: 
        describe, and implement, the major algorithms for well known combinatorial problems such as Sorting, Matrix Multiplication, Minimum Spanning Trees, and other problems listed in the syllabus.demonstrate familiarity with algorithmic strategies such as Divide-and-Conquer, the Greedy strategy and Dynamic Programming; and should be able to test these strategies on new problems and identify whether or not they are likely to be useful for those problems.construct clear and rigorous arguments to prove correctness/running-time bounds of algorithms, and should be able to present these arguments in writing.explain the importance of the data structures used in a particular implementation of an algorithm, and how the data structure that is used can affect the running time.construct simple lower bound arguments for algorithmic problems, and to understand the relationship between upper and lower bounds. Also should be able to perform simple average-case analyses of the running-time of an algorithm, as well as worst-case analyses. |  
Reading List 
| Introduction to Algorithms (3rd Edition), Cormen, Leiserson, Rivest, Stein: . MIT Press, 2002. (Course text) |  
Contacts 
| Course organiser | Dr Aris Filos-Ratsikas Tel:
 Email: Aris.Filos-Ratsikas@ed.ac.uk
 | Course secretary | Miss Rose Hynd Tel: (0131 6)50 5194
 Email: rhynd@ed.ac.uk
 |   |  |