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

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ß
#4
vote_ok
von JKooP (18090 Punkte) - 05.03.2021 um 15:44 Uhr
NET 5.x; C# 9.x; VS-2019

Quellcode ausblenden C#-Code
using System.Collections.Generic;
using System.Linq;

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

IEnumerable<int> SelfDividingNumbers(int min, int max)
{
    foreach (var l in Enumerable.Range(min, max - min + 1))
        if (l.ToString().All(x => l % char.GetNumericValue(x) == 0))
            yield return l;
}

Kommentare:

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

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

Du scheinst einen AdBlocker zu nutzen. Ich würde mich freuen, wenn du ihn auf dieser Seite deaktivierst und dich davon überzeugst, dass die Werbung hier nicht störend ist.