Symulacja interaktywna
Symulacja przedstawia złożoności obliczeniowe różnych rozwiązań tego samego problemu obliczeniowego – znalezienia NWD dwóch liczb. Dane są dwie liczby – oraz , takie że . Naszym zadaniem jest znalezienie ich największego wspólnego dzielnika. By to zrobić, możemy wykorzystać kilka metod.
Rozwiązanie siłowe (ang. brute force) – to metoda polegająca na sprawdzeniu wszystkich możliwych przypadków w celu znalezienia rozwiązania danego problemu, w tym wypadku sprawdzamy wszystkie liczby całkowite od 1 do , poszukując tych, które są wspólnymi dzielnikami liczb oraz – złożoność tego rozwiązania to .
Algorytm Euklidesa z wykorzystaniem iteracji – jego złożoność obliczeniowa wynosi . Więcej na temat tego algorytmu znajdziesz w e‑materiale Algorytm EuklidesaAlgorytm Euklidesa.
Algorytm Euklidesa z użyciem rekurencji – jego złożoność obliczeniowa wynosi również . Więcej na temat tego algorytmu znajdziesz w e‑materiale Algorytm EuklidesaAlgorytm Euklidesa.
Rozkład na czynniki pierwsze – jego złożoność obliczeniowa to .
Algorytm Steina – jego złożoność obliczeniowa to .
Algorytm służący do wyliczania największego wspólnego dzielnika dwóch liczb naturalnych. Pozwala znacząco zmniejszyć czas obliczeń. Rozwiązanie opiera się na przyjęciu następujących założeń:
Przyjmując, że oraz , zakładamy, że obliczenia pozostaną poprawne.
Dla parzystych , mamy .
Gdy jest liczbą parzystą, a jest nieparzystą (pamiętajmy o przemienności NWD), to .
Dla nieparzystych , mamy .
Kroki od 2. do 4. wykonujemy w pętli do momentu, w którym albo .
Przeanalizuj wykres interaktywny. Przyjrzyj się temu, jak zmienia się liczba wykonywanych operacji dla poniższych par liczb:
przypadek 1: 27 oraz 5,
przypadek 2: 20 oraz 23,
przypadek 3: 15 oraz 12,
przypadek 4: 94 oraz 87.
Przygotuj własną symulację, w której zapiszesz złożoność obliczeniową dla różnych rozwiązań tego samego problemu, np. sortowania zbioru liczb. Złożoność oblicz dla różnych przypadków.