Rekursives Programm zum Anzeigen von Primzahlen

-Migjo-

Mitglied
Moin Leute,

ich bin gerade noch in der Übung die Rekursion zu "lernen" und mache deshalb alte Übungsaufgaben vom Prof., wo wir die Iteration angewendet haben, nur versuche ich das Problem mittels Rekursion zu lösen. Beim Primzahlentester war meine Idee, dass die Methode testet, ob die abgegebene Zahl % x ungleich null ergibt, ist dies der Fall soll es x um eins erhöht werden, bis x == i ist, sollte ein Modulo schon mittendrin auftreten, soll x auf 2 zurückgesetzt werden und die Grenze (i) um eins verringert werden.


import java.util.Scanner;

public class Primzahlen {
public static void main(String[] args) {
Scanner sc = new Scanner (System.in);
int i, x=2;
System.out.print("Bis zu welcher Zahl soll geprueft werden? : ");
i = sc.nextInt();
sc.close();
Primzahlentester (i,x);

}
public static boolean Primzahlentester (int b, int c) {
if(b == 2) {
System.out.print(b);
return true;
}
else if (b != 2 && b == c) {
System.out.println(b);

return Primzahlentester(b--, c=2);
}
else if (b%c != 0) {
return Primzahlentester (b, c++);
}
else {

return Primzahlentester(b--, c=2);
}
}
}
 

mihe7

Top Contributor
Wenn Du mit vernünftigen Bezeichnern - auch in Deiner Beschreibung - arbeiten würdest, wäre vieles klarer. Auch, wenn Du auf Zuweisungen jeglicher Art innerhalb von Parametern verzichten würdest, hättest Du ein Problem weniger. Abgesehen davon, ist diese Form von Zuweisungen absolut hässlich.

Der Post-Inkrement-Operator (EDIT: natürlich auch der Post-Dekrement-Operator) liefert den Wert der Variablen vor der Erhöhung. Du dürftest also in eine Endlosrekursion laufen, sofern b nicht durch 2 teilbar ist.
 
K

kneitzel

Gast
Also neben den Informationen von @mihe7 möchte ich noch darauf hinweisen, dass es auch noch zusätzlich von der Logik her Unsinn ist:
return Primzahlentester(b--, c=2);

Du veränderst b und c - aber da die Methode verlassen wird und der Gültigkeitsbereich der Variablen verlassen wird, macht es absolut keinen Sinn.

Ein paar Regeln, die ich Dir ans Herz legen würde:

a) Mach Parameter immer final, also z.B.:
public static boolean Primzahlentester (final int b, final int c) {
Das hat dann sozusagen den Vorteil, dass der Compiler Dich verhaut und uns diese Arbeit schlicht abnimmt. (Parameter zu ändern ist einfach extrem unschön und führt auch leicht bei Anfängern zu Problemen!)

b) Post- und Prä-Increment / -Decrement: Diese wirklich nur als eigenständige Anweisung verwenden. Also bitte wirklich niemals Code wie:
return Primzahlentester(b--, c=2);

Es ist toll, dass ihr diese Ausdrücke lernt und dann als Verständniskontrolle gefragt werdet, was z.B. ++c % c-- ist. Aber das hat mit wirklicher Entwicklung absolut nichts zu tun. Es ist toll, wenn man sich selbst ein Bein stellen will und Code schreiben möchte, den man als Anfänger vermutlich noch nicht einmal beim schreiben versteht....

Bei dem Code
return Primzahlentester(b--, c=2);
wäre also aus meiner Sicht der Aufruf:
return Primzahlentester(b-1, 2);
So du den Inhalt von b um eins reduziert aufrufen möchtest... Aber ich habe fast die Befürchtnis, das Du das Call By Value bei Parametern nicht ganz verstanden hast und möchstest, dass die Variablen, die übergeben wurden, geändert haben möchtest .... Aber das ist nur eine Vermutung ... So dem so sein sollte: Such bei Google einmal nach: Java Call by value
 

-Migjo-

Mitglied
Hey Mihe und JustNobody, erstmal vielen Dank für die Tipps. Mir fehlt noch einiges an Praxiserfahrung und eure Tipps haben geholfen, dass das Programm jetzt -wie in meiner Überlegung - funktioniert.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
G Primzahlentester als rekursives Programm! Java Basics - Anfänger-Themen 13
C Rekursives Backtracking beim Spiel Peg Java Basics - Anfänger-Themen 22
G Rekursives Programmieren --> harmonische Reihe Java Basics - Anfänger-Themen 3
S Rekursives Problem.... Java Basics - Anfänger-Themen 16
S Rekursives Durchlaufen eines Verzeichnisses - AccessDeniedException behandeln Java Basics - Anfänger-Themen 1
S Rekursives Zählen einer Zahl Java Basics - Anfänger-Themen 8
J Rekursives Parsen (ohne Reg Expressions) Java Basics - Anfänger-Themen 8
S Rekursives Umdrehen, Spiegeln. etc. von Strings Java Basics - Anfänger-Themen 3
I Rekursives Löschen in Binärem Suchbaum Java Basics - Anfänger-Themen 2
L rekursives spiel programmieren Java Basics - Anfänger-Themen 4
G Rekursives aufrufen führt zu StackOverflowError Panel durchl Java Basics - Anfänger-Themen 5
M Rekursives suchen im TreeMenu Java Basics - Anfänger-Themen 10
N Rekursives suchen in einer Liste Java Basics - Anfänger-Themen 8
H Rekursives einlesen von Lokalen Ordner Java Basics - Anfänger-Themen 4
W Java-PRogramm liest als EXE-File Nicht USB, jedoch aus NetBeans Java Basics - Anfänger-Themen 23
tomzen Programm ignoriert in der Ausführung Code Java Basics - Anfänger-Themen 8
S Erstes Programm: Hallo Welt funktioniert nicht. Java Basics - Anfänger-Themen 3
A "Hello World"-Programm läuft nicht Java Basics - Anfänger-Themen 16
J Delay erzeugen, ohne Programm zu blockieren Java Basics - Anfänger-Themen 7
Ü Dead Code im Programm? Java Basics - Anfänger-Themen 13
M Java Mail Programm Java Basics - Anfänger-Themen 4
E Java Programm zur anzeige, ob Winter- oder Sommerzeit herrscht Java Basics - Anfänger-Themen 62
M Mini Jar-Programm Java Basics - Anfänger-Themen 51
G JTable Listselectionlistener friert das Programm ein Java Basics - Anfänger-Themen 8
M Das Programm stellt nichts dar Java Basics - Anfänger-Themen 2
K Programm compilierbar aber nicht ausführbar... Java Basics - Anfänger-Themen 21
Z Programm Ideen Java Basics - Anfänger-Themen 8
P Wie kann ich in meinem Java Programm etwas dauerhaft speichern? Java Basics - Anfänger-Themen 5
P Wie kann ich beispielsweise Speicherstände eines Spiels DAUERHAFT in meinem Programm speichern? Java Basics - Anfänger-Themen 3
H Java-Programm zur Ausgabe von Zuständen Java Basics - Anfänger-Themen 80
G Kann Java-Programm nicht als jar aufrufen, auch als EXE nicht Java Basics - Anfänger-Themen 19
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
T Programm stürzt ab Java Basics - Anfänger-Themen 40
KeinJavaFreak Erste Schritte Programm "Java(TM) Platform SE binary " nicht vorhanden Java Basics - Anfänger-Themen 1
G Programm läuft durch, ohne Eingabe aus dem Chat abzuwarten Java Basics - Anfänger-Themen 4
N Programm Funktioniert mit .txt Datei aber nicht mit .rtf Datei Java Basics - Anfänger-Themen 2
N Interpreter-Fehler Compiler zeigt keine Fehler an, aber das Programm läuft nicht (BlueJ) Java Basics - Anfänger-Themen 2
D Java Programm mit Batch-Datei starten Java Basics - Anfänger-Themen 32
Jul1n4tor Programm mit Scanner und If-Statements Java Basics - Anfänger-Themen 2
D Wie sehe ich ein Java-Programm? Java Basics - Anfänger-Themen 27
K Ist das Programm schlecht bzw. schlampig programmiert ? Java Basics - Anfänger-Themen 9
Zrebna Kann Java Programm nicht in Konsole ausführen Java Basics - Anfänger-Themen 1
K Warum läuft das Programm nicht(bzw. nicht richtig) Java Basics - Anfänger-Themen 4
M Von Eclipse zum richtigen Programm Java Basics - Anfänger-Themen 1
nbergmann IntelliJ: Wie lade ich ein fertiges Programm aus dem Lehrbuch? Java Basics - Anfänger-Themen 26
D Anfängerfrage zu meinem Programm. Java Basics - Anfänger-Themen 15
nbergmann Eclipse: Lehrbuch-Programm startet nicht Java Basics - Anfänger-Themen 22
I Jetty starten von Programm (Main) Java Basics - Anfänger-Themen 27
Kydo Programm Beschreibung Java Basics - Anfänger-Themen 3
nbergmann Eclipse: Lehrbuch-Programm startet nicht Java Basics - Anfänger-Themen 7
T Java FXML selbes Fenster verschiedene Stellen im Programm Java Basics - Anfänger-Themen 5
frager2345 Programm erstellen ohne Autoboxing und Unboxing Java Basics - Anfänger-Themen 13
D JAVA Programm schreiben Java Basics - Anfänger-Themen 46
P exportiertes Programm funktioniert nur teilweise Java Basics - Anfänger-Themen 7
J Mein Programm läuft bei der ersten Eingabe nicht mehr weiter, woran liegt das? Java Basics - Anfänger-Themen 6
M Wo hält das Programm an? Java Basics - Anfänger-Themen 11
J Mein Java Programm lässt sich nicht mehr bearbeiten Java Basics - Anfänger-Themen 2
Fugover Programm funktioniert nicht Java Basics - Anfänger-Themen 11
Fugover Kopfrechnen-Programm Java Basics - Anfänger-Themen 6
NadimArazi Wie kann ich eine collision detection für die Paddles in meinem Pong Programm hinzufügen? Java Basics - Anfänger-Themen 4
sserio Wieso funktioniert mein Programm nicht Java Basics - Anfänger-Themen 2
sserio Größtes Palindrom-Produkt Programm funktioniert nur halb Java Basics - Anfänger-Themen 23
J selbst erstellte Datei mit Programm öffnen Java Basics - Anfänger-Themen 10
F nach Methode Programm nicht beenden Java Basics - Anfänger-Themen 9
A wie kann ich es in meinem Programm rein tun Java Basics - Anfänger-Themen 8
S Fehler beim Programm Java Basics - Anfänger-Themen 2
Jose05 Fehler im Programm feststellen Java Basics - Anfänger-Themen 2
F Kann mir jemand kurz dieses Programm erklären? Java Basics - Anfänger-Themen 22
I Programm erkennt nicht an das Array zurückgegeben wird trotz Initialisierung *einfach* Java Basics - Anfänger-Themen 9
J Nach dem Exportieren funktioniert mein Programm nicht mehr Java Basics - Anfänger-Themen 8
P Mein Programm wird zwar erfolgreich Compiliert, öffnet sich aber nicht Java Basics - Anfänger-Themen 6
J Kann ich mein Programm so schreiben? Java Basics - Anfänger-Themen 4
A Lotto Programm Java Basics - Anfänger-Themen 3
S Programm erstellen Java Basics - Anfänger-Themen 3
A Verarbeiten einer Excel Datei durch das java-Programm Java Basics - Anfänger-Themen 3
S MinMax Programm erstellen Java Basics - Anfänger-Themen 4
J Interpreter-Fehler Programm gibt nicht gewünschtes Ergebnis aus Java Basics - Anfänger-Themen 11
brypa Programm mit Eingabe Java Basics - Anfänger-Themen 129
B Java Programm soll mit Python kommunizeren Java Basics - Anfänger-Themen 1
SpigBin Programm läuft nicht weiter... Java Basics - Anfänger-Themen 10
M JAVA Programm in Website einbinden Java Basics - Anfänger-Themen 19
B Programm, dass alle 3 Tage eine Webseite öffnet? Java Basics - Anfänger-Themen 20
B Programm beendet sich nicht und weiteres seltsames Verhalten Java Basics - Anfänger-Themen 9
N Eclipse Programm normal ausführen Java Basics - Anfänger-Themen 1
D Programm auf Enter warten lassen Java Basics - Anfänger-Themen 2
C Programm das feststellen kann, ob eine eingegebene Zahl einem Schaltjahr entspricht, richtig geschrieben? Java Basics - Anfänger-Themen 11
C Brauche Hilfe um ein Programm zu schreiben Java Basics - Anfänger-Themen 8
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
nevel Programm für die Summer der Zahlen 1- 1ß Java Basics - Anfänger-Themen 12
WAB9703-04 Programm zum automatischen Ausfüllen von Formularen programmieren Java Basics - Anfänger-Themen 3
OSchriever Jar-Programm läuft auf Windows aber nicht auf Linux(Raspberri Pi4) Java Basics - Anfänger-Themen 22
G Programm Code Java Basics - Anfänger-Themen 5
CptK Achsenskalierung in Koordinatensystem hängt Programm auf Java Basics - Anfänger-Themen 5
H Kann eine while-Schleife ein Programm blockieren? Java Basics - Anfänger-Themen 8
TimoN11 Mail Programm mit Java? Java Basics - Anfänger-Themen 1
Sajeel Chattha Dieses Programm umschreiben Java Basics - Anfänger-Themen 5
J Programm beenden ohne System.exit() oder Runtime.exit() Java Basics - Anfänger-Themen 5
F Java Programm, das kleine Buchstaben in einem String zählen soll und bei großen Buchstaben oder Sonderzeichen abbrechen soll. Java Basics - Anfänger-Themen 5
A Programm Histogram Java Basics - Anfänger-Themen 2
C Was ist nötig für ein Java-Programm auf Server für Website Java Basics - Anfänger-Themen 18

Ähnliche Java Themen


Oben