CITB308 Структури от данни

Учебна програма, график за лекциите, учебни материали [2023/2024]


Тема на лекция
Дата
1.
Език за програмиране С++ и ООП
Базисни елементи, изрази, функции, класове.
Наследственост и полиморфизъм, шаблони, обработка на изключения.

Chapters 1: C++ Programming [html] (1-56)
Basic C++ Programming Elements, Expressions, Functions, Classes
Chapters 2: Оbject Oriented Design [html] (61-96)
Inheritance and Polymorphism, Templates, Exceptions

2.
Анализ на алгоритми
Време за изпълнение, псевдокод, анализ на алгоритми, асимптотичната нотация, асимптотичен анализ.

Chapter 3: Analysis Tools [pdf] [html](107-134)
Running Time and Pseudo-Code, Analysis of Algorithms, Asymptotic Notation, Asymptotic Analysis [Wiki],
[Lec 2 | MIT 6.046J / 18.410J Introduction to Algorithms]

3.
Стек, опашка и дек
Стек, опашка, свързан списък, дек.

Chapter 4: Stacks, Queues, and Recursion [html] (143-202)
Stacks, Queues, Linked Lists, Double-Ended Queues

4.
Вектори, списъци и редици
Вектори, списъци, редици, метод на мехурчето с редици, итератори, Йерархия от редични абстрактни типове данни (АТД).

Chapter 5: Vectors, Lists, and Sequences [html] (203-252)
Vectors, Lists, Sequences, Case Study: Bubble-Sort on a Sequence, Iterators, A Hierarchy of Sequence ADTs

5. Тест 1

6.
Дървета - първа част
Дървета АТД, базови алгоритми за дървета.

Chapter 6: Trees I [html] (253-272)
The Tree Abstract Data Type, Basic Algorithms on Trees

7.
Дървета - втора част
Двоични дървета, структури от данни за представяне на дървета.

Chapter 6:Trees II [html] (273-300)
Binary Trees, Data Structures for Representing Trees

8.
Приоритетна опашка - първа част
Приоритетна опашка АТД, реализиране на приоритетна опашка с редица.

Chapter 7: Priority Queues I [html] (311-329)
The Priority Queue Abstract Data Type, Implementing a Priority Queue with a Sequence

9.
Приоритетна опашка - втора част
Хип, реализиране на приоритетна опашка като хип.

Chapter 7: Priority Queues II [html] (330-348)
Heaps, Implementing a Priority Queue as a Heap

10.
Тест 2

11.
Речници - първа част
Речник АТД, наредени речници.

Chapter 8: Dictionaries I [html] (363-402)
The Dictionary Abstract Data Type, Ordered Dictionaries

12.
Речници - втора част
Хеширане.

Chapter 8: Dictionaries II [html] (363-402)
Hash Tables

13.
Търсещи дървата - първа част
Двоични търсещи дървета, AVL-дървета.

Chapter 9: Search Trees I [html] (411-436)
Binary Search Trees, AVL Trees

14.
Търсещи дървета - втора част
Multi-Way търсещи дървета, (2,4)-дървета, червено-черни дървета.

Chapter 9: Search Trees II [html] (437-467)
Multi-Way Search Trees, (2,4) Trees, Red-Black Trees

15.
Тест 3


Сесия