Analiza algorytmu Euklidesa: Różnice pomiędzy wersjami

Z Lem
Skocz do: nawigacji, wyszukiwania
Linia 8: Linia 8:
 
:(n3) <math>(\forall n)[m:=0; \mathbf{while}\ m \neq n\ \mathbf{do}\ n:=n+1\ \mathbf{od}](m=n)</math>
 
:(n3) <math>(\forall n)[m:=0; \mathbf{while}\ m \neq n\ \mathbf{do}\ n:=n+1\ \mathbf{od}](m=n)</math>
  
Możemy zdefiniować relację mniejszości
+
Możemy zdefiniować relacje mniejszości
 
+
{|
'''Definicja'''
+
|-
 +
| '''Definicja'''
  
 
<math>x<y\ \stackrel{df}{\equiv}\ \neg (x=y) \wedge \left[\begin{array}{l}   
 
<math>x<y\ \stackrel{df}{\equiv}\ \neg (x=y) \wedge \left[\begin{array}{l}   
Linia 19: Linia 20:
 
\mathbf{od}  
 
\mathbf{od}  
 
\end{array} \right](r=x)</math>
 
\end{array} \right](r=x)</math>
 
+
| &nbsp; 
'''Definicja'''
+
|'''Definicja'''
  
 
<math>x\leq y\ \stackrel{df}{\equiv}\  \left[\begin{array}{l}   
 
<math>x\leq y\ \stackrel{df}{\equiv}\  \left[\begin{array}{l}   
Linia 29: Linia 30:
 
\mathbf{od}  
 
\mathbf{od}  
 
\end{array} \right](r=x)</math>
 
\end{array} \right](r=x)</math>
 
+
|}
 
oraz operację odejmowania
 
oraz operację odejmowania
  
Linia 45: Linia 46:
 
(wynik = q)
 
(wynik = q)
 
</math>
 
</math>
 +
 +
i operację dodawania
 +
 +
'''Definicja'''
 +
Operacja dodawania jest określona tak
 +
 +
<math>x  + y\ \stackrel{df}{\equiv}\ \left[\begin{array}{l} 
 +
r:=x;\ q:=0; \\
 +
\mathbf{while}\ q \neq y \ 
 +
\mathbf{do}
 +
\quad r:=r+1;\ q:=q+1 \
 +
\mathbf{od}; \\
 +
\end{array} \right]
 +
(wynik = r)
 +
</math>
 +
  
 
'''Lemat''' (aksjomat Archimedesa)
 
'''Lemat''' (aksjomat Archimedesa)
Linia 51: Linia 68:
 
<math> \left[\begin{array}{l}   
 
<math> \left[\begin{array}{l}   
 
r:=n;  \\  
 
r:=n;  \\  
\mathbf{while}\ r < m \   
+
\mathbf{while}\ r \leq m \   
 
\mathbf{do}  
 
\mathbf{do}  
 
\quad r:=r+n;  \  
 
\quad r:=r+n;  \  

Wersja z 12:06, 15 lut 2013

Należy udowodnić że algorytm zawsze kończy obliczenia.

Algorytmiczne aksjomaty liczb naturalnych:

(n1) [math](\forall n) (n+1 \neq 0 ) [/math]
(n2) [math](\forall n)(\forall m)(n+1=m+1 \Rightarrow n=m)[/math]
(n3) [math](\forall n)[m:=0; \mathbf{while}\ m \neq n\ \mathbf{do}\ n:=n+1\ \mathbf{od}](m=n)[/math]

Możemy zdefiniować relacje mniejszości

Definicja

[math]x\lty\ \stackrel{df}{\equiv}\ \neg (x=y) \wedge \left[\begin{array}{l} r:=0; \\ \mathbf{while}\ r\neq x \land r \neq y \\ \mathbf{do} \\ \quad r:=r+1 \\ \mathbf{od} \end{array} \right](r=x)[/math]

  Definicja

[math]x\leq y\ \stackrel{df}{\equiv}\ \left[\begin{array}{l} r:=0; \\ \mathbf{while}\ r\neq x \land r \neq y \\ \mathbf{do} \\ \quad r:=r+1 \\ \mathbf{od} \end{array} \right](r=x)[/math]

oraz operację odejmowania

Definicja

Jeśli [math]y \lt x [/math] to operacja odejmowania jest określona tak

[math]x \stackrel{.}{-}y\ \stackrel{df}{\equiv}\ \left[\begin{array}{l} r:=y;\ q:=0; \\ \mathbf{while}\ r \neq x \ \mathbf{do} \quad r:=r+1;\ q:=q+1 \ \mathbf{od}; \\ \end{array} \right] (wynik = q) [/math]

i operację dodawania

Definicja Operacja dodawania jest określona tak

[math]x + y\ \stackrel{df}{\equiv}\ \left[\begin{array}{l} r:=x;\ q:=0; \\ \mathbf{while}\ q \neq y \ \mathbf{do} \quad r:=r+1;\ q:=q+1 \ \mathbf{od}; \\ \end{array} \right] (wynik = r) [/math]


Lemat (aksjomat Archimedesa)

Jeśli [math] 0\ltn \lt m [/math] to [math] \left[\begin{array}{l} r:=n; \\ \mathbf{while}\ r \leq m \ \mathbf{do} \quad r:=r+n; \ \mathbf{od}; \\ \end{array} \right] (r\gtm) [/math]