C# :: Aufgabe #358 :: Lösung #5

5 Lösungen Lösungen öffentlich
#358

Divisionsrest (Modulo) aus einer Zahl und ihrer Ziffern

Anfänger - C# von JKooP - 11.02.2021 um 19:17 Uhr
Ziel soll es sein, eine beliebige Integer-Zahl dahingehend zu überprüfen,
ob die Zahl dividiert durch jede ihrer Ziffern immer den Rest 0 ergibt (Modulo = mod).

Dazu soll eine Methode/Funktion erstellt werden, die zwei Integer-Zahlen (Min, Max) aufnimmt
und alle Lösungen im angegebenen Bereich (Min-Max) als Integer-Array zurückgibt.

Beispiel:

Min = 1
Max = 20
Lösung: = [ 1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 12, 15 ]

Erläuterung (Auszug):

Zahl 9: 9 mod 9 = 0 => true (gilt für jede einstellige Zahl)
Zahl 10: 10 mod 1 = 0; 10 mod 0 = 10 => false, da nicht beide den Rest 0 haben
Zahl 12: 12 mod 1 = 0; 12 mod 2 = 0 => true
Zahl 14: 14 mod 1 = 0; 14 mod 4 = 2 => false, da nicht beide den Rest 0 haben

Viel Spaß
#5
vote_ok
von JKooP (18090 Punkte) - 23.04.2021 um 22:23 Uhr
NET 5.x; C# 9.x; VS-2019
Quellcode ausblenden C#-Code
using System.Collections.Generic;

const int min = 1, max = 100;
System.Console.WriteLine(string.Join(", ", SelfDividingNumbers(min, max)));

IEnumerable<int> SelfDividingNumbers(int min, int max)
{
    for (var n = min; n <= max; n++)
    {
        var m = n;
        var b = true;
        while (m > 0)
        {
            var t = m % 10;
            if (t == 0 || n % t != 0)
            {
                b = false;
                break;
            }
            m /= 10;
        }
        if (b) yield return n;
    }
}

Kommentare:

Für diese Lösung gibt es noch keinen Kommentar

Bitte melden Sie sich an um eine Kommentar zu schreiben.
Kommentar schreiben