- Nazwa przedmiotu:
- Algorytmy zaawansowane
- Koordynator przedmiotu:
- Dr inż. Michał Dębski, Dr Michał Tuczyński
- Status przedmiotu:
- Obowiązkowy
- Poziom kształcenia:
- Studia II stopnia
- Program:
- Informatyka i Systemy Informacyjne
- Grupa przedmiotów:
- Wspólne
- Kod przedmiotu:
- 1120-INMSI-MSP-0009
- Semestr nominalny:
- 1 / rok ak. 2020/2021
- Liczba punktów ECTS:
- 4
- Liczba godzin pracy studenta związanych z osiągnięciem efektów uczenia się:
- 1. godziny kontaktowe – 45 h; w tym
a. obecność na wykładach – 30 h
b. obecność na ćwiczeniach – 0 h
c. obecność na zajęciach projektowych – 15 h
2. przygotowanie do ćwiczeń – 0 h
3. przygotowanie do zajęc projektowych – 15 h
4. zapoznanie się z literaturą – 5 h
5. konsultacje – 5 h
6. przygotowanie do egzaminu i obecność na egzaminie – 30 h
Łączny nakład pracy studenta wynosi 100 h co odpowiada 4 pkt. ECTS
- Liczba punktów ECTS na zajęciach wymagających bezpośredniego udziału nauczycieli akademickich:
- 1. obecność na wykładach – 30 h
2. obecność na ćwiczeniach – 0 h
3. obecność na zajęciach projektowych – 15 h
4. konsultacje – 5 h
Razem 50 h, co odpowiada 2 pkt. ECTS
- Język prowadzenia zajęć:
- polski
- Liczba punktów ECTS, którą student uzyskuje w ramach zajęć o charakterze praktycznym:
- 1. obecność na zajęciach projektowych – 15 h
2. przygotowanie do zajęć projektowych – 15 h
Razem 30 h, co odpowiada 1 pkt. ECTS
- Formy zajęć i ich wymiar w semestrze:
-
- Wykład30h
- Ćwiczenia0h
- Laboratorium0h
- Projekt15h
- Lekcje komputerowe0h
- Wymagania wstępne:
- Matematyka dyskretna, Algorytmy i struktury danych, Teoria algorytmów i obliczeń
- Limit liczby studentów:
- Bez limitu
- Cel przedmiotu:
- Celem przedmiotu jest zapoznanie studentów z zaawansowanymi metodami projektowania algorytmów, dowodzenia ich poprawności oraz obliczania złożoności. W szczególności student po zaliczeniu przedmiotu powinien znać:
- algorytmy zachłanne, kody Huffmana, matroidy,
- programowanie dynamiczne, problem mnożenia łańcucha macierzy,
- algorytmy dziel i zdobywaj, mnożenie liczb całkowitych, mnożenie macierzy, znajdowanie pary najbliższych punktów,
- zaawansowane algorytmy grafowe, problem maksymalnego skojarzenia w grafie,
- algorytmy aproksymacyjne, schematy aproksymacji, problem sumy podzbioru.
- Treści kształcenia:
- Algorytmy zachłanne, kody Huffmana, matroidy, programowanie dynamiczne, mnożenie łańcucha macierzy, usuwanie rekursji, algorytmy dziel i zdobywaj, szacowanie złożoności obliczeniowej algorytmów, mnożenie liczb całkowitych, mnożenie macierzy, algorytmy geometrii obliczeniowej, znajdowanie pary najbliższych punktów, konstruowanie domknięcia wypukłego, problem wyszukiwania wzorca, algorytmy aproksymacyjne.
- Metody oceny:
- Na ocenę końcową składają się: punkty za egzamin końcowy (60%) oraz punkty za projekt programistyczny (40%).
- Egzamin:
- tak
- Literatura:
- 1. L. Banachowski, K. Diks, W. Rytter, Algorytmy i struktury danych, WNT, 1997.
2. T.H. Cormen, C.E. Leiserson, R.L. Rivest, Wprowadzenie do algorytmów, WNT, 2000.
3. M.R. Garey, D.S. Johnson, Computers and Intractability, Freeman 1979.
4. M.A. Weiss, Data Structures and Algorithms in C++, Adison Wesley 1999.
- Witryna www przedmiotu:
- brak
- Uwagi:
Efekty uczenia się
Profil ogólnoakademicki - wiedza
- Charakterystyka W01
- Posiada wiedzę o zaawansowanej algorytmice, strukturach danych i metodach tworzenia algorytmów
Weryfikacja: egzamin
Powiązane charakterystyki kierunkowe:
I2_W02
Powiązane charakterystyki obszarowe:
P7U_W, I.P7S_WG.o
- Charakterystyka W02
- Posiada szeroką wiedzę w zakresie teorii grafów
Weryfikacja: egzamin
Powiązane charakterystyki kierunkowe:
I2_W01, I2SI_W07
Powiązane charakterystyki obszarowe:
P7U_W, I.P7S_WG.o
Profil ogólnoakademicki - umiejętności
- Charakterystyka U01
- Potrafi wykorzystać wiedzę matematyczną do analizy i optymalizacji rozwiązań informatycznych
Weryfikacja: ocena projektu programistycznego, w tym terminowości
Powiązane charakterystyki kierunkowe:
I2_U02
Powiązane charakterystyki obszarowe:
- Charakterystyka U02
- Potrafi projektować wydajne algorytmy i uzasadniać ich poprawność
Weryfikacja: ocena projektu programistycznego, w tym terminowości
Powiązane charakterystyki kierunkowe:
I2_U03
Powiązane charakterystyki obszarowe:
- Charakterystyka U03
- Potrafi przeprowadzić analizę czasowej złożoności obliczeniowej algorytmu
Weryfikacja: ocena projektu programistycznego, w tym terminowości
Powiązane charakterystyki kierunkowe:
I2_U03
Powiązane charakterystyki obszarowe:
- Charakterystyka U04
- Potrafi projektować algorytmy wielowątkowe i analizować ich wydajność
Weryfikacja: ocena projektu programistycznego, w tym terminowości
Powiązane charakterystyki kierunkowe:
I2_U04
Powiązane charakterystyki obszarowe:
- Charakterystyka U05
- Potrafi pracować indywidualnie, w zespole oraz kierować niedużym zespołem
Weryfikacja: ocena projektu programistycznego, w tym terminowości
Powiązane charakterystyki kierunkowe:
I2_U11
Powiązane charakterystyki obszarowe:
Profil ogólnoakademicki - kompetencje społeczne
- Charakterystyka K01
- Jest świadomy roli wiedzy w rozwiązywaniu problemów i rozumie potrzebę zasięgania opinii ekspertów
Weryfikacja: ocena projektu programistycznego, w tym terminowości
Powiązane charakterystyki kierunkowe:
I2_K05
Powiązane charakterystyki obszarowe:
- Charakterystyka K02
- Ma świadomość odpowiedzialności za wspólnie realizowane zadania w ramach pracy zespołowej
Weryfikacja: ocena projektu programistycznego, w tym terminowości
Powiązane charakterystyki kierunkowe:
I2_K05
Powiązane charakterystyki obszarowe: