Skip to main content

Data Structures and Algorithms (5 cr)

Code: 5051128-3008

General information


Enrollment
02.12.2023 - 31.12.2023
Registration for the implementation has ended.
Timing
01.01.2024 - 30.04.2024
Implementation has ended.
Number of ECTS credits allocated
5 cr
Local portion
5 cr
Mode of delivery
Contact learning
Unit
Engineering and Business
Campus
Kupittaa Campus
Teaching languages
Finnish
English
Seats
20 - 50
Degree programmes
Degree Programme in Information and Communications Technology
Degree Programme in Information and Communication Technology
Teachers
Noora Maritta Nieminen
Teacher in charge
Noora Maritta Nieminen
Groups
PTIVIS22P
Game and Interactive Technologies
Course
5051128

Realization has 6 reservations. Total duration of reservations is 12 h 0 min.

Time Topic Location
Wed 03.04.2024 time 12:00 - 14:00
(2 h 0 min)
Practice GAIT, Tietorakenteet ja algoritmit 5051128-3008
ICT_B1039 IT telakka
Tue 09.04.2024 time 10:00 - 12:00
(2 h 0 min)
Lecture, Tietorakenteet ja algoritmit 5051128-3008
ICT_C1027_Lambda LAMBDA
Wed 10.04.2024 time 12:00 - 14:00
(2 h 0 min)
Practice GAIT, Tietorakenteet ja algoritmit 5051128-3008
ICT_B1039 IT telakka
Tue 16.04.2024 time 10:00 - 12:00
(2 h 0 min)
Lecture, Tietorakenteet ja algoritmit 5051128-3008
ICT_C1027_Lambda LAMBDA
Tue 23.04.2024 time 10:00 - 12:00
(2 h 0 min)
Lecture, Tietorakenteet ja algoritmit 5051128-3008
ICT_C1027_Lambda LAMBDA
Wed 24.04.2024 time 12:00 - 14:00
(2 h 0 min)
Practice GAIT, Tietorakenteet ja algoritmit 5051128-3008
ICT_B1039 IT telakka
Changes to reservations may be possible.

Evaluation scale

H-5

Content scheduling

January– April 2024

January: Algorithmic Thinking and Analysis
• pseudocode, flowcharts
• efficiency and algorithmic complexity

February: Basic Data Structures
• Arrays, Linked List, Stack, Queue

March: Advanced Data Structures
• Hash table, Trees, Graphs

April: Sorting Algorithms, Search Algorithms
• Bubble, Selection, Insertion, Merge and Quick Sort

Objective

After completing the course the student can:
- explain the most common data structures
- apply the most common data structures and algorithms connected to the use of these structures
- evaluate the efficiency of algorithms.

Content

- lists, stacks, queues, trees, graphs and hash tables
- analysing and evaluating algorithms   
- designing algorithms       
- sorting methods  
- search algorithms

Materials

Lecture and practice session material in ItsLearning, e.g. PowerPoint presentations, Jupyter notebook / Python files, etc.
All material is provided in English

Teaching methods

Attending to lectures: teacher will provide both theoretical background and practical examples on a dedicated topic
Attending practice sessions: the theory is put into action in practice - we will see solutions to previous exercises + practice new topics
Individual work: Completing the assignments individually after face-to-face sessions

Exam schedules

Midterm 1 will be held in February (close to winter break), topics are "Algorithms and complexity" and "Basic data structures"
Midterm 2 will be held at the end of the course in April, topics are "Advanced data structures" and "search algorithms"

You will have the chance to retake midterm 1 at the end of the course when you also take the midterm 2 exam.

There is one retake exam for the entire course at the beginning of May.

International connections

Understanding data structures and algorithmic efficiency / complexity are essential in many ways. During this course, the student will gain both theoretical and practical understanding on these topics.

Students will learn to use pseudocode / flowcharts to describe algorithms and analyze their complexity. Practical understanding is gained through coding exercises. We will use Python as our main coding language.

Completion alternatives

Ask teacher, if there is an ongoing suitable online course (FiTech / Coursera or equivalent).
CampusOnline courses ARE NOT accepted!

Student workload

Lectures 2h / week (all three groups together)
Practice sessions 2h / week (three small groups)
Individual work outside school: reading, studying, preparing the weekly programming practice tasks

Qualifications

Introduction to Programming, or equivalent programming skills

Further information

ItsLearning
Email

Go back to top of page