Veröffentlicht 25. Oktober 201410 j Ich muss ein Programm mit C# schreiben, welches mir bei Eingabe einer Beliebigen Zahl die dazu gehörigen Primfaktoren ausgibt. Bsp. Eingabe: 100 Ausgabe: 2*2*5*5 Bekomm es allerdings nicht zusammen. Irgendwelche Anregungen? Bin für jede Hilfe dankbar
25. Oktober 201410 j Bis die Zahl 1 ist: - Prüfen, ob die Zahl durch die erste Primzahl teilbar ist. -> Wenn ja, teilen, ausgeben und nochmal probieren -> Wenn nicht, mit der nächsten Primzahl probieren
25. Oktober 201410 j hier noch ein kleiner tip for (int i = 2; i <= zahl; i++) { if (zahl % i == 0) { } }
26. Oktober 201410 j Autor So wird mir leider nur das Ergebnis ausgegeben bei Eingabe von hundert bspw. 100:50 static void Main(string[] args) { int zahl; int i; Console.WriteLine("Bitte geben Sie eine Zahl ein: "); zahl = Convert.ToInt32(Console.ReadLine()); for (i = 2; i <= zahl; i++) { if (zahl % i == 0) Console.WriteLine("{0}: " + zahl / i, zahl); else if (zahl % i != 0) i++; Console.WriteLine("{0}: " + zahl / i, zahl); break; } Console.ReadLine(); komm einfach nicht drauf...
26. Oktober 201410 j Du musst durch die Primzahlen teilen, Du inkrementierst i, d.h. da steht irgendwann 4 drin, aber das ist keine Primzahl. i darf immer nur eine Primzahl sein
26. Oktober 201410 j So wird mir leider nur das Ergebnis ausgegeben bei Eingabe von hundert bspw. 100:50Erstens musst du i ausgeben, nicht zahl, und das auch nur, wenn du einen Teiler gefunden hast. Zweitens musst du zahl durch i teilen, wenn du einen Teiler gefunden hast. Also wirklich zahl ändern. Du musst durch die Primzahlen teilen, Du inkrementierst i, d.h. da steht irgendwann 4 drin, aber das ist keine Primzahl. i darf immer nur eine Primzahl sein Wenn er den Rest richtig macht, ist das sogar egal. Die Zahl ist nicht mehr durch 4 teilbar, wenn er die 2 immer schön rausdividiert hat.
26. Oktober 201410 j Autor static void Main(string[] args) { int zahl; int i = 2; bool prim; Console.WriteLine("Bitte geben Sie eine Zahl ein: "); zahl = Convert.ToInt32(Console.ReadLine()); prim = i % 1 == 0 && i % i != 0; i = prim; while(zahl % i != 0) { i++; } if (zahl % i == 0) Console.WriteLine("{0}: " + i, zahl); Console.ReadLine(); } ich habe nun das Problem dass er mir eine Fehlermeldung ausspuckt bei i = prim
26. Oktober 201410 j ich habe nun das Problem dass er mir eine Fehlermeldung ausspuckt bei i = prim Naja, das ist ja auch Blödsinn. Was willst du mit dieser Zuweisung denn erreichen?
26. Oktober 201410 j also das mit den Primzahlen würde ich wieder vergessen, hier geht es um eine kleine aufgabe die gelöst werden soll und nicht um eine effiziente Funktion die riesige Zahlen lösen kann auf schnellste weise was dir glaub ich noch klar werden sollte ist: wenn folgendes zutrifft: if (zahl % i == 0), dann heißt das, dass i ein teil der lösung ist, und dann musst du die zahl durch dieses i teilen und die forschleife von vorne beginnen kann dir gerne meine lösung posten, aber ich denk das bringt dir nicht viel
26. Oktober 201410 j forschleife von vorne beginnen Bitte nicht ein schon komplexes Problem noch ineffizienter loesen als notwendig, natuerlich beginnst Du bei dem entsprechenden Teiler wieder, der bei der letzten Iteration ermittelt worden ist, alle kleineren Primzahlfaktoren wurden ja vorher schon ausgeschlossen (ergibt sich ja allein schon aus dem Distributivgesetz, wenn ein Produkt schon vorher nicht durch einen moeglichen Faktor teilbar war, wird es das auch niemals sonst sein).
27. Oktober 201410 j Bitte nicht ein schon komplexes Problem noch ineffizienter loesen als notwendig, natuerlich beginnst Du bei dem entsprechenden Teiler wieder, der bei der letzten Iteration ermittelt worden ist, alle kleineren Primzahlfaktoren wurden ja vorher schon ausgeschlossen (ergibt sich ja allein schon aus dem Distributivgesetz, wenn ein Produkt schon vorher nicht durch einen moeglichen Faktor teilbar war, wird es das auch niemals sonst sein). ja ok, da hast du natürlich recht, aber das sind doch bereits Sachen die man erst berücksichtigen muss wenn das Ergebnis stimmt und es ans optimieren geht
Erstelle ein Konto oder melde dich an, um einen Kommentar zu schreiben.