import Foundation
func recGGTEuklid(a: Int, b: Int) -> Int {
/* In der Funktion wird eine zweite Variable mit der Bezeichnung resultat
deklariert. Da es hierbei um eine lokale Variable handelt, gibt es keinen
Konflikt mit der anderen Variable, die die gleiche Bezeichnung trägt.*/
var resultat : Int
/* Bevor die Berechnung beginnt, wird geprüft, ob die Variable a 0 ist. Im
Fall, dass die Variable null ist, ist das Ergebnis die andere Zahl b.
Ist a ungleich null, wird die Funktion recGGTEuklid mit vertauschten und
angepassten Argumenten recGGTEuklid(b MOD a, a) aufgerufen.*/
if a == 0 {
resultat = b
} else {
resultat = recGGTEuklid(a: b % a, b: a)
}
return resultat
}
// Main
// Für die erste Zahl wird die Variable A deklariert.
var a : Int
// Für die zweite Zahl wird die Variable B deklariert.
var b : Int
// Die Variable resultat wird für das Ergebnis deklariert.
var resultat : Int
print("Dieses Programm berechnet den größten gemeinsamen Teiler von zwei Zahlen mithilfe des Verfahrens von Euklid.")
print("Geben Sie die erste Zahl an: ")
// Der eingegebene Wert der ersten Zahl wird in der Variablen A gespeichert.
a = Int(readLine()!)!
print("Geben Sie die zweite Zahl an:")
// Der eingegebene Wert wird in der Variablen B gespeichert.
b = Int(readLine()!)!
/* Innerhalb der Funktion recGGTEuklid wird der größte gemeinsame Teiler der
zwei Zahlen a und b nach dem Verfahren von Euklid rekursiv berechnet.*/
resultat = recGGTEuklid(a: a, b: b)
print(resultat)