import java.util.*;
import java.lang.Math;

public class JavaApplication {
    private static Scanner input = new Scanner(System.in);

    public static void main(String[] args) {
        // Im folgenden Programm soll der größte gemeinsame Teiler (kurz ggT) von zwei Zahl n und m berechnet werden.
        // Für die erste Zahl wird die Variable m deklariert.
        int m;
        
        // Für die zweite Zahl wird die Variable n deklaiert.
        int n;
        
        System.out.println("Geben Sie die erste Zahl an: ");
        
        // Der eingegebene Wert wird an die Variable m übergeben.
        m = input.nextInt();
        System.out.println("Geben Sie die zweite Zahl an:");
        
        // Der eingegebene Wert wird an die Variable n übergeben.
        n = input.nextInt();
        
        // Die Funktion recGGT wird mit den Zahlen n und m als Argument aufgerufen und liefert als Ergebnis den größten gemeinsamen Teiler der beiden Zahlen zurück.
        System.out.println(recGGT(m, n));
    }
    
    public static int recGGT(int m, int n) {
        // Die Funktion recGGT berechnet den größten gemeinsamen Teiler zweier Zahlen. Die zwei Zahlen wurden der Funktion bereits als Argument übergeben.
        // Die Variable r ist eine Hilfsvariable, die für die spätere Berechnung benötigt wird.
        int r;
        
        // Das Ergebnis der Berechnung wird am Ende in der Variablen resultat gespeichert.
        int resultat;
        
        // Nun wird geprüft, ob die zweite Zahl m kleiner als die erste Zahl n ist, falls ja, wird die Berechnung gestartet und im Fall das m größer ist, wird die Funktion recGGT mit vertauschten Argumenten, also recGGT(n, m) aufgerufen.
        if (m < n) {
            resultat = recGGT(n, m);
        }
        r = m % n;
        
        // Solange die Variable r ungleich 0 ist, wird die Funktion recGGT(n, r) aufgerufen. Im Fall, dass die Variable r gleich 0 ist, ist die Berechnung beendet. Und das Ergebnis wird in der Variablen resultat gespeichert.
        if (r == 0) {
            resultat = n;
        } else {
            resultat = recGGT(n, r);
        }
        
        return resultat;
    }
}
        
        
akzeptieren ablehen

Diese Website verwendet Cookies und Zählpixel, um Ihnen die bestmögliche Nutzung dieser Website zu ermöglichen.Learn more about cookies sehen Sie auch Datenschutz