Data Structures & Algorithms (G5117)

15 credits, Level 4

Spring teaching

This module introduces data structures and algorithms for computer scientists. You’ll learn about key data structures like arrays, linked lists, stacks, queues, trees, hash tables, and graphs, presented as implementations of relevant interfaces.

You’ll also explore fundamental computational problems, such as sorting and finding the shortest paths in graphs, along with important algorithms like insertion sort, selection sort, merge sort, heap sort, Dijkstra’s algorithm, and Bellman-Ford’s algorithm.

Algorithms will be presented in pseudocode, with a focus on their efficiency and asymptotic behavior, and you’ll also examine the correctness of some of these algorithms.

Teaching

75%: Lecture
25%: Practical (Laboratory)

Assessment

100%: Examination (Unseen examination)

Contact hours and workload

This module is approximately 150 hours of work. This breaks down into about 44 hours of contact time and about 106 hours of independent study. The University may make minor variations to the contact hours for operational reasons, including timetabling requirements.

We regularly review our modules to incorporate student feedback, staff expertise, as well as the latest research and teaching methodology. We’re planning to run these modules in the academic year 2025/26. However, there may be changes to these modules in response to feedback, staff availability, student demand or updates to our curriculum.

We’ll make sure to let you know of any material changes to modules at the earliest opportunity.