Algorytm Euklidesa: Różnice pomiędzy wersjami
Z Lem
								
												
				| Linia 2: | Linia 2: | ||
| (* Dane: x>0 i y>0 liczby naturalne *) | (* Dane: x>0 i y>0 liczby naturalne *) | ||
| − | + | ::<math>\color{red}\mathbf{Precondition}\ typ(x)=typ(y)=typ(n)=typ(m)=typ(r)=typ(q)=typ(max)=\mathbb{N}\ \land\ typ(n\_mniejsze)=Boolean  </math> | |
| (* Wynik:  nwd(x,y)  *) | (* Wynik:  nwd(x,y)  *) | ||
Wersja z 10:16, 16 lut 2013
(* Algorytm Euklidesa inaczej *)
(* Dane: x>0 i y>0 liczby naturalne *)
- [math]\color{red}\mathbf{Precondition}\ typ(x)=typ(y)=typ(n)=typ(m)=typ(r)=typ(q)=typ(max)=\mathbb{N}\ \land\ typ(n\_mniejsze)=Boolean [/math]
 
(* Wynik: nwd(x,y) *)
n:=x; m:=y;
while n ≠ m do
- [math]\color{red}\mathbf{Oznaczenie}\ niech\ l=max(n,m) [/math]
 
- r:=0;
- while r ≠n and r ≠m
- do
- r:=r+1
 
- od;
- if r=n then n_miejsze:=true; max:=m else n_mniejsze:=false; max:=n fi;
- [math]\color{blue}\mathbf{Stwierdzenie}\ (n\ltm \wedge m=max(n,m) \vee m\ltn \wedge n=max(n,m)) [/math]
 
- q:=0;
- while r≠max
- do
- r:= r+1; q:=q+1
 
- od;
- [math]\color{blue}\mathbf{Stwierdzenie}\ q = |m-n| \land (1 \leq q \lt max(n,m))\land r=max(n,m) [/math]
 
- if n_mniejsze then m:=q else n := q fi
- [math]\color{blue}\mathbf{Stwierdzenie}\ max(n,m) \lt \color{red}l [/math]
 
od ( wynik = n)
- przejdź do analizy algorytmu Euklidesa
 
 
 
 
 
 
 
 
 
