Zaawansowane algorytmy i struktury danych: Różnice pomiędzy wersjami

Z Studia Informatyczne
Przejdź do nawigacjiPrzejdź do wyszukiwania
Diks (dyskusja | edycje)
Sank (dyskusja | edycje)
 
(Nie pokazano 31 wersji utworzonych przez 5 użytkowników)
Linia 18: Linia 18:


=== Zawartość ===
=== Zawartość ===
* Złożone struktury danych (3)
** słowniki i ich implementacje - drzewa typu ''splay'', listy z przeskokami,
** kolejki priorytetowe - kolejki dwumianowe i kopce Fibonacciego,
** sumowanie zbiorów rozłącznych.
* Zaawansowane algorytmy tekstowe (3)
** struktury danych dla tekstów - tablice i drzewa sufiksowe, grafy podsłów,
** regularności w tesktach - okresowość, symetrie, powtórzenia,
** algorytmy z błędami,
** algorytm Aho-Corasica.
* Wielomiany i FFT (1)
** mnożenie wielomianów,
** dzielenie wielomianów,
** obliczanie wartości,
** interpolacja.
* Zaawansowane algorytmy grafowe
* Zaawansowane algorytmy grafowe
** Problemy ścieżkowe (2)
** Problemy ścieżkowe
*** algorytm Bellmana-Forda,
*** algorytm Bellmana-Forda
*** problemy ścieżkowe i mnożenie macierzy,
*** problemy ścieżkowe i mnożenie macierzy
*** algorytm Floyda-Warshalla,
*** algorytm Floyda-Warshalla
*** algorytm Johnsona.
*** algorytm Johnsona
 
** Skojarzenia
** Skojarzenia (2)
*** skojarzenia w grafach dwudzielnych - algorytmy Hopcrofta-Karpa
*** skojarzenia w grafach dwudzielnych - algorytmy Hopcrofta-Karpa,
*** skojarzenia w grafach dowolnych - algorytm Edmondsa
*** ważone skojarzenia w grafach dwudzielnych.
** Maksymalny przepływ:
 
*** algorytm Forda-Fulkersona
** Maksymalny przepływ: (2)
*** algorytm Edmondsa-Karpa
*** algorytm Forda-Fulkersona,
*** algorytm Dinica
*** algorytm Edmondsa-Karpa,
* Zaawansowane algorytmy tekstowe
*** algorytm Dintiz'a.
** algorytm Boyera Moore'a
 
**Wyszukiwanie wzorca w pamięci stałej
* Algorytmy geometryczne (2)
** regularności w tesktach - symetrie, powtórzenia
** przynależnoźć punktu do wielokąta,
* Algorytmy geometryczne
** znajdowanie otoczki wypukłej,
** przynależnoźć punktu do wielokąta
** technika zamiatania.
** znajdowanie otoczki wypukłej
 
** technika zamiatania i problem najmniej odległej pary punktów
* Algorytmy równoległe (2)
* Algorytmy równoległe
** sieci sortujące,
**  
** PRAM.
** Abstrakcyjny model PRAM
 
**sumy prefiksowe i sortowanie na PRAMie
* Randomizacja: (2)
**algorytm jednoczesnych podstawień
** algorytmy Monte Carlo i Las Vegas,
**równoległa kontrakcja drzew
** problem minimalnego przekroju,
* Wielomiany i FFT
** lemat Zippela-Schwartza i jego zastosowania.
** mnożenie wielomianów
** dzielenie wielomianów
** obliczanie wartości
** interpolacja
* Randomizacja
** algorytmy Monte Carlo i Las Vegas
** problem maksymalnego przekroju
** problem długiej ścieżki


=== Literatura ===
=== Literatura ===
Linia 69: Linia 59:
# ''Algorytmy i struktury danych'', L. Banachowski, K. Diks, W. Rytter, Wydawnictwa Naukowo - Techniczne, 2006.
# ''Algorytmy i struktury danych'', L. Banachowski, K. Diks, W. Rytter, Wydawnictwa Naukowo - Techniczne, 2006.
#  ''Randomized Algorithms'', R. Motwani, P. Raghavan, Cambridge University Press, 1995.
#  ''Randomized Algorithms'', R. Motwani, P. Raghavan, Cambridge University Press, 1995.
# ''Jewels of stringology'', W. Rytter, M. Crochemore, World Scientific, 2003.


== Moduły ==
== Moduły ==


* [[ZASD Moduł 1| Kolejki priorytetowe I]] ([[ZASD Ćwiczenia 1|Ćwiczenia]])
* [[Zaawansowane_algorytmy_i_struktury_danych/Wykład 1| Zaawansowane algorytmy tekstowe I]] ([[Zaawansowane_algorytmy_i_struktury_danych/Ćwiczenia 1|Ćwiczenia]])
* [[ZASD Moduł 2| Kolejki priorytetowe II]] ([[ZASD Ćwiczenia 2|Ćwiczenia]])
* [[Zaawansowane_algorytmy_i_struktury_danych/Wykład 2| Zaawansowane algorytmy tekstowe II]] ([[Zaawansowane_algorytmy_i_struktury_danych/Ćwiczenia 2|Ćwiczenia]])
* [[ZASD Moduł 3| Wielomiany i FFT]] ([[ZASD Ćwiczenia 3|Ćwiczenia]])
* [[Zaawansowane_algorytmy_i_struktury_danych/Wykład 3| Zaawansowane algorytmy tekstowe III]] ([[Zaawansowane_algorytmy_i_struktury_danych/Ćwiczenia 3|Ćwiczenia]])
* [[ZASD Moduł 4| Algorytmy macierzowe]] ([[ZASD Ćwiczenia 4|Ćwiczenia]])
* [[Zaawansowane_algorytmy_i_struktury_danych/Wykład 4| Wielomiany i FFT]] ([[Zaawansowane_algorytmy_i_struktury_danych/Ćwiczenia 4|Ćwiczenia]])
* [[ZASD Moduł 5| Najkrótsze ścieżki I]] ([[ZASD Ćwiczenia 5|Ćwiczenia]])
* [[Zaawansowane_algorytmy_i_struktury_danych/Wykład 5| Zaawansowane algorytmy grafowe I: Najkrótsze ścieżki]] ([[Zaawansowane_algorytmy_i_struktury_danych/Ćwiczenia 5|Ćwiczenia]])
* [[ZASD Moduł 6| Najkrótsze ścieżki II]] ([[ZASD Ćwiczenia 6|Ćwiczenia]])
* [[Zaawansowane_algorytmy_i_struktury_danych/Wykład 6| Zaawansowane algorytmy grafowe II: Najkrótsze ścieżki]] ([[Zaawansowane_algorytmy_i_struktury_danych/Ćwiczenia 6|Ćwiczenia]])
* [[ZASD Moduł 7| Skojarzenia w grafach dwudzielnych]] ([[ZASD Ćwiczenia 7|Ćwiczenia]])
* [[Zaawansowane_algorytmy_i_struktury_danych/Wykład 7| Zaawansowane algorytmy grafowe III: Skojarzenia w grafach dwudzielnych]] ([[Zaawansowane_algorytmy_i_struktury_danych/Ćwiczenia 7|Ćwiczenia]])
* [[ZASD Moduł 8| Ważone skojarzenia w grafach dwudzielnych]] ([[ZASD Ćwiczenia 8|Ćwiczenia]])
* [[Zaawansowane_algorytmy_i_struktury_danych/Wykład 8| Zaawansowane algorytmy grafowe IV: Skojarzenia w grafach dowolnych]] ([[Zaawansowane_algorytmy_i_struktury_danych/Ćwiczenia 8|Ćwiczenia]])
* [[ZASD Moduł 9| Przepływy I]] ([[ZASD Ćwiczenia 9|Ćwiczenia]])
* [[Zaawansowane_algorytmy_i_struktury_danych/Wykład 9| Zaawansowane algorytmy grafowe V: Maksymalny przepływ I]] ([[Zaawansowane_algorytmy_i_struktury_danych/Ćwiczenia 9|Ćwiczenia]])
* [[ZASD Moduł 10| Przepływy II]] ([[ZASD Ćwiczenia 10|Ćwiczenia]])
* [[Zaawansowane_algorytmy_i_struktury_danych/Wykład 10| Zaawansowane algorytmy grafowe VI: Maksymalny przepływ II]] ([[Zaawansowane_algorytmy_i_struktury_danych/Ćwiczenia 10|Ćwiczenia]])
* [[ZASD Moduł 11| Algorytmy geometryczne]] ([[ZASD Ćwiczenia 11|Ćwiczenia]])
* [[Zaawansowane_algorytmy_i_struktury_danych/Wykład 11| Algorytmy geometryczne I]] ([[Zaawansowane_algorytmy_i_struktury_danych/Ćwiczenia 11|Ćwiczenia]])
* [[ZASD Moduł 12| Algorytmy teorioliczbowe]] ([[ZASD Ćwiczenia 12|Ćwiczenia]])
* [[Zaawansowane_algorytmy_i_struktury_danych/Wykład 12| Algorytmy geometryczne II]] ([[Zaawansowane_algorytmy_i_struktury_danych/Ćwiczenia 12|Ćwiczenia]])
* [[ZASD Moduł 13| Algorytmy aproksymacyjne]] ([[ZASD Ćwiczenia 13|Ćwiczenia]])
* [[Zaawansowane_algorytmy_i_struktury_danych/Wykład 13| Algorytmy równoległe I]] ([[Zaawansowane_algorytmy_i_struktury_danych/Ćwiczenia 13|Ćwiczenia]])
* [[ZASD Moduł 14| Algorytmy randomizowane]] ([[ZASD Ćwiczenia 14|Ćwiczenia]])
* [[Zaawansowane_algorytmy_i_struktury_danych/Wykład 14| Algorytmy równoległe II]] ([[Zaawansowane_algorytmy_i_struktury_danych/Ćwiczenia 14|Ćwiczenia]])
 
* [[Zaawansowane_algorytmy_i_struktury_danych/Wykład 15| Algorytmy randomizowane]] ([[Zaawansowane_algorytmy_i_struktury_danych/Ćwiczenia 15|Ćwiczenia]])
== Literatura uzupełniająca ==
''opcjonalnie''

Aktualna wersja na dzień 21:38, 3 paź 2006

Forma zajęć

Wykład (30 godzin) + laboratorium (30 godzin)

Opis

Projektowanie i analiza algorytmów. Przegląd zaawansowanych algorytmów i struktur danych. Wprowadzenie do zaawansowanych technik projektowania algorytmów.

Sylabus

Autorzy

  • Krzysztof Diks
  • Wojciech Rytter
  • Piotr Sankowski

Wymagania wstępne

  • Algorytmy i struktury danych
  • Analiza matematyczna
  • Algebra liniowa z geometrią analityczną

Zawartość

  • Zaawansowane algorytmy grafowe
    • Problemy ścieżkowe
      • algorytm Bellmana-Forda
      • problemy ścieżkowe i mnożenie macierzy
      • algorytm Floyda-Warshalla
      • algorytm Johnsona
    • Skojarzenia
      • skojarzenia w grafach dwudzielnych - algorytmy Hopcrofta-Karpa
      • skojarzenia w grafach dowolnych - algorytm Edmondsa
    • Maksymalny przepływ:
      • algorytm Forda-Fulkersona
      • algorytm Edmondsa-Karpa
      • algorytm Dinica
  • Zaawansowane algorytmy tekstowe
    • algorytm Boyera Moore'a
    • Wyszukiwanie wzorca w pamięci stałej
    • regularności w tesktach - symetrie, powtórzenia
  • Algorytmy geometryczne
    • przynależnoźć punktu do wielokąta
    • znajdowanie otoczki wypukłej
    • technika zamiatania i problem najmniej odległej pary punktów
  • Algorytmy równoległe
    • Abstrakcyjny model PRAM
    • sumy prefiksowe i sortowanie na PRAMie
    • algorytm jednoczesnych podstawień
    • równoległa kontrakcja drzew
  • Wielomiany i FFT
    • mnożenie wielomianów
    • dzielenie wielomianów
    • obliczanie wartości
    • interpolacja
  • Randomizacja
    • algorytmy Monte Carlo i Las Vegas
    • problem maksymalnego przekroju
    • problem długiej ścieżki

Literatura

  1. Wprowadzenie do algorytmów, Thomas H. Cormen , Charles E. Leiserson , Ronald L. Rivest , Clifford Stein, Wydawnictwa Naukowo - Techniczne, 2004.
  2. Algorytmy i struktury danych, L. Banachowski, K. Diks, W. Rytter, Wydawnictwa Naukowo - Techniczne, 2006.
  3. Randomized Algorithms, R. Motwani, P. Raghavan, Cambridge University Press, 1995.
  4. Jewels of stringology, W. Rytter, M. Crochemore, World Scientific, 2003.

Moduły