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

#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ß
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ß
#1

von hollst (13980 Punkte)
- 14.02.2021 um 16:59 Uhr

using static System.Console; //.net 5.0.2 VS Community 2019 int imin = 1, imax = 301; WriteLine(aufgabe_358(imin, imax).ToMyString()); ReadKey(); //------------------------------------------------------------------------------ int[] aufgabe_358(int imin, int imax) { var temp = new System.Collections.Generic.List<int>(); for (var i = imin; i <= imax; i++) { var ii = i; var bo = true; do { var mo = ii % 10; if (Mod(i, mo) != 0) bo = false; ii /= 10; } while (ii != 0); if (bo) temp.Add(i); } return temp.ToArray(); } int Mod(int z1, int z2) => z2 != 0 ? z1 % z2 : z1; static class Extension { public static string ToMyString(this int[] X) { var sb = new System.Text.StringBuilder(); foreach (int x in X) sb.Append($"{x} "); return sb.ToString(); } }
Kommentare:
Für diese Lösung gibt es noch keinen Kommentar
Seite 1 von 0
1