Python - wyrównanie algorytmu
Aby twierdzić, że algorytm jest skuteczny, potrzebujemy pewnych narzędzi matematycznych jako dowodu. Te narzędzia pomagają nam w dostarczaniu matematycznie satysfakcjonującego wyjaśnienia wydajności i dokładności algorytmów. Poniżej znajduje się lista niektórych z tych narzędzi matematycznych, których można użyć do uzasadnienia jednego algorytmu względem drugiego.
- Direct Proof:
Jest to bezpośrednia weryfikacja oświadczenia za pomocą bezpośrednich obliczeń. Na przykład suma dwóch liczb parzystych jest zawsze liczbą parzystą. W takim przypadku wystarczy dodać dwie badane liczby i zweryfikować wynik jako parzysty.
- Proof by induction:
Tutaj zaczynamy od konkretnego przypadku prawdy, a następnie uogólniamy ją na wszystkie możliwe wartości, które są częścią prawdy. Podejście polega na przyjęciu przypadku zweryfikowanej prawdy, a następnie udowodnieniu, że jest ona również prawdziwa dla następnego przypadku dla tego samego danego warunku. Na przykład wszystkie liczby dodatnie w postaci 2n-1 są nieparzyste. Udowodnimy to dla pewnej wartości n, a następnie udowodnimy to dla następnej wartości n. Dzięki temu stwierdzenie jest ogólnie prawdziwe na podstawie dowodu indukcji.
- Proof by contraposition:
Dowód ten oparty jest na warunku Jeśli nie A implikuje nie B, to A implikuje B. Prosty przykład jest taki, że jeśli kwadrat n jest parzysty, to n musi być parzyste. Ponieważ jeśli kwadrat na n nie jest parzysty, to n nie jest parzyste.
- Proof by exhaustion:
Jest to podobne do bezpośredniego dowodu, ale ustala się go, badając każdy przypadek oddzielnie i udowadniając każdy z nich. Przykładem takiego dowodu jest twierdzenie o czterech kolorach.