using System;

public class MyProgram
{
    public static void Main(string[] args)
    {
        // Das Programm berechnet den größten gemeinsamen Teiler zweier Zahlen A und B, ggT(A, B), rekursiv nach dem Verfahren von Euklid.
        // Für die erste Zahl wird die Variable A deklariert.
        int a;
        
        // Für die zweite Zahl wird die Variable B deklariert.
        int b;
        
        // Die Variable resultat wird für das Ergebnis deklariert.
        int resultat;
        
        Console.WriteLine("Dieses Programm berechnet den größten gemeinsamen Teiler von zwei Zahlen mithilfe des Verfahrens von Euklid.");
        Console.WriteLine("Geben Sie die erste Zahl an: ");
        
        // Der eingegebene Wert der ersten Zahl wird in der Variablen A gespeichert.
        a = (int) inputValue();
        Console.WriteLine("Geben Sie die zweite Zahl an:");
        
        // Der eingegebene Wert wird in der Variablen B gespeichert.
        b = (int) inputValue();
        
        // 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, b);
        Console.WriteLine(resultat);
    }
    
    public static int RecGGTEuklid(int a, int b)
    {
        // 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.
        int resultat;
        
        // 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(b % a, a);
        }
        
        return resultat;
    }
    
    // .NET kann nur einzelne Zeichen oder ganze Zeilen aus der  Konsole lesen. 
    // Die folgende Funktion löst das Problem.
    private static double inputValue()
    {
        double result;
        while (!double.TryParse(Console.ReadLine(), out result));
        return result;
    }
}
        
        
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