Primzahlen berechnen

java1986

Mitglied
Hallo,
ich bin ziemlich neu in der Java Programmierung.
Ich muss ein Programm schreiben, dass eine vorgegebene Anzahl von Primzahlen berechnet.
D.h. ich sollte berechnen, dass z.B. die vierte Primzahl die 7 ist.

Hier hab ich schonmal ein Quelltext zum berechnen der Primzahlen. Weiter komm ich allerdings nicht. Ich hoffe mir kann jemand helfen.
Java:
public class Primzaheln {

	public static void main(String[] args){
		int zahl;
		int limit = 20;
		int teiler;
		int zaehler;
		
		for(zahl = 1; zahl <= limit; zahl++){
			if(zahl != 1){
				teiler = 0;
				for(zaehler = 1; zaehler <= zahl; zaehler++){
					if(zahl % zaehler == 0) {
						teiler++;
					}
				}
				
			if (teiler == 2)
				System.out.println(zahl);	
			}
			
		}
	}
}
 

java1986

Mitglied
Ich weiß nicht, wie ich das Programm umschreiben muss, damit ich sagen kann, es soll genau 5 Primzahlen berechnen und dann die fünfte ausgeben
 

Flown

Administrator
Mitarbeiter
Also du kannst auf jedenfall dein Problem in zwei Schritten berechnen:

1. Schritt: Die Prüfung einer Zahl auf prim-Eigenschaft

Pseudo:
Code:
for i from 2 to sqrt(n):
  if(n % i == 0) then return false
end for
return true

2. Schritt berechnen der n-ten Primzahl

Pseudo:
Code:
number = 2
prime = -1
primeNr = 0
while(primeNr < n) then
  if(number prime?) then
    prime = number
    increment(primeNr)
  end if
  increment(number)
end while
return prime
 

Tarrew

Top Contributor
Der Pseudo-Code von Flown ist eig. schon sehr gut.

Aber ok, ich gehe mal davon aus, dass dein bestehender Code jetzt funktioniert.
Dazu definierst du noch ein int n;
Für n=1 wird die erste, für n=2 die zweite, für n=3 die dritte Primzahl berechnet usw.

Dann kannst du deine äußerste for-Schleife auch einfach ändern:

Java:
for (limit= 0; limit < n; zahl++) {
... /dein bestehender Code

limit ist jetzt ein bisschen umfunktioniert. Jedes mal, wenn du eine Primzahl gefunden hast inkrementierst du limit.

Vielleicht kommst da ja jetzt drauf, was dann die n-te Primzahl ist.
 
Zuletzt bearbeitet:

Tarrew

Top Contributor
Die Schleife bricht ab, wenn limit = n ist. Wenn du eine Primzahl gefunden hast, musst du also limit++ rechnen.
Machst du das auch?
 

java1986

Mitglied
ja hab ich, aber wenn ich dann für n z.B. 10 hab, bricht die Schleife bei der Primzahl 7 ab. Sie soll ja aber bei 29 abbrechen.
Vielleicht versteh ich's auch grad einfach nicht
 

Tarrew

Top Contributor
Ich vermute das liegt daran, dass du die geschweiften Klammern nicht gesetzt hast:
Java:
int zahl = 0;
		int limit;
		int teiler;
		int zaehler;
		int n = 10;

		for (limit = 0; limit < n; zahl++) {
			if (zahl != 1) {
				teiler = 0;
				for (zaehler = 1; zaehler <= zahl; zaehler++) {
					if (zahl % zaehler == 0) {
						teiler++;
					}
				}

				if (teiler == 2) {
					System.out.println(zahl);
					limit++;
				}
			}

		}
		System.out.println(n + ". Primzahl ist: " + //hier musst du nochmal nachdenken);
	}

Du musst dir nur überlegen, welche Zahl der n-te Primzahl ist, nachdem die Schleife abbricht.
 

Tarrew

Top Contributor
Trotzdem würde ich deinen Algorithmus nochmal an den Pseudocode von Flown anpassen.
Dein Code ist durchaus verbesserungswürdig ;)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
D Primzahlen berechnen funktioniert nicht Allgemeine Java-Themen 2
J Primzahlen generieren Allgemeine Java-Themen 6
G Anzahl Primzahlen im Intervall Allgemeine Java-Themen 3
C Primzahlen Server Allgemeine Java-Themen 3
E Primzahlen - Sieb des Eratosthenes Allgemeine Java-Themen 40
B Primzahlen Berechnung optimieren Allgemeine Java-Themen 7
B Primzahlen test Allgemeine Java-Themen 3
Encera Größe eines Objektes in Byte berechnen Allgemeine Java-Themen 2
bittedanke Wie benötigte Bits berechnen (Huffmankodierung) Allgemeine Java-Themen 7
C Koordinaten LONG/LAT eines neuen Punktes in bestimmter Entfernen und Winkel berechnen Allgemeine Java-Themen 3
ReinerCoder Kombinationsmöglichkeiten der Textfelder berechnen Allgemeine Java-Themen 14
S Mittelwert anhand eines Stream berechnen Allgemeine Java-Themen 5
MiMa Prüfziffer einer EAN Nummer berechnen Allgemeine Java-Themen 4
C Java Script Pause berechnen Allgemeine Java-Themen 5
D Kgv aller Paare aus einem Array mit n integer berechnen Allgemeine Java-Themen 5
MaxG. Best Practice Alle Kombinationen berechnen Allgemeine Java-Themen 3
Aruetiise Funktion(y = mx+n) in String speichern und berechnen Allgemeine Java-Themen 9
N Das große O berechnen Allgemeine Java-Themen 2
A OOP Problem beim Berechnen der größten Fläche eines Ringes Allgemeine Java-Themen 19
N Kombinationen beliebiger Größe berechnen Allgemeine Java-Themen 1
The Pi Anzahl der Gewichtscheiben berechnen Allgemeine Java-Themen 11
B Hirsch-Index berechnen Allgemeine Java-Themen 11
B Umfang berechnen für Polygone Allgemeine Java-Themen 18
C pplet Mitelwert Berechnen Allgemeine Java-Themen 0
K F-Verteilung FINV in Java berechnen Allgemeine Java-Themen 4
A Helligkeit eines Bildes berechnen Allgemeine Java-Themen 1
P Methoden Alle Kombinationen aus 2 Karten berechnen Allgemeine Java-Themen 2
C mp3-Lied Dauer berechnen Allgemeine Java-Themen 1
L Winkel eines Vektors berechnen [Anfängerprob] Allgemeine Java-Themen 5
R Threads Taskzeit berechnen Allgemeine Java-Themen 12
S Eclipse Entfernung berechnen Allgemeine Java-Themen 16
T Kreis und sekant schnittpunkt berechnen mit latitude longitude Allgemeine Java-Themen 4
B Java Diffentialgleichungen berechnen Allgemeine Java-Themen 3
W 2D-Grafik Kontrast eines Bildes berechnen Allgemeine Java-Themen 6
T Taylorpolynom berechnen Allgemeine Java-Themen 14
S Erste Schritte Mittelsenkrechte berechnen Allgemeine Java-Themen 3
P Matrix Kurtosis berechnen Allgemeine Java-Themen 40
S Werte aus 2 eindimensionale boolean arrays mithilfe von logischen operatoren berechnen Allgemeine Java-Themen 6
S Teiler Berechnen Allgemeine Java-Themen 6
Kr0e Differenzen von Bildern berechnen - Remote control Allgemeine Java-Themen 2
D md5 berechnen für BufferedImage Allgemeine Java-Themen 5
J bewegliche Feiertage berechnen Allgemeine Java-Themen 7
W Rechnungsbetrag berechnen Allgemeine Java-Themen 2
reibi Checksumme für ein File berechnen Allgemeine Java-Themen 12
M Integral berechnen Allgemeine Java-Themen 5
S Algorithmus um nächst folgende Primzahl zu berechnen Allgemeine Java-Themen 7
Developer_X Prozentdifferenz berechnen. Allgemeine Java-Themen 13
M Kombinationen über rekursiven Algorithmus berechnen? Allgemeine Java-Themen 10
M Monatliche Zeitspannen berechnen Allgemeine Java-Themen 3
Ark Arkussinus effizient berechnen Allgemeine Java-Themen 12
Iron Monkey Potenzzahlen mit shiftLeft berechnen? Allgemeine Java-Themen 13
N Rechenzeit berechnen? Allgemeine Java-Themen 3
H Schrifthöhe berechnen / Swing Allgemeine Java-Themen 5
T ungerade zahlen berechnen Allgemeine Java-Themen 3
X Suche Java Klasse die Feiertage berechnen kann Allgemeine Java-Themen 2
G ganzzahlige Potenz schnell berechnen Allgemeine Java-Themen 4
M Lautstärke von Audiosignal live berechnen Allgemeine Java-Themen 7
S CRC wert berechnen ergibt 0 ? Allgemeine Java-Themen 9
data89 Die Größe eines Strings in Byte berechnen? Allgemeine Java-Themen 12
T Arbeitsstunden berechnen Allgemeine Java-Themen 8
M Date Range auswerten und die Monate berechnen Allgemeine Java-Themen 2
V Setter zum Berechnen nutzen? Allgemeine Java-Themen 5
G Richtung berechnen anhand Koordinaten Allgemeine Java-Themen 3
P Dauer (Tage, Stunden, Minuten, Sekunden) berechnen Allgemeine Java-Themen 5
D Mittelwert einer Menge von Doubles berechnen Allgemeine Java-Themen 3
P Winkel berechnen. Allgemeine Java-Themen 3
0 Alle Teiler einer Zahl performant berechnen? Allgemeine Java-Themen 9
B Was würdet ihr dafür berechnen? Allgemeine Java-Themen 7
T MessageDigest von einem char[] berechnen Allgemeine Java-Themen 7
S den zweit niedrigsten wert in einem array berechnen Allgemeine Java-Themen 2
E CRC 8 Berechnen Allgemeine Java-Themen 1
M Math-String-Formel berechnen lassen Allgemeine Java-Themen 4
B Ellipsen Kreisbahnen berechnen! Allgemeine Java-Themen 11
M Alle möglichen Kombinationen von mehreren Objekten berechnen Allgemeine Java-Themen 6
clemente lanman und nt password berechnen Allgemeine Java-Themen 7
J an und bn berechnen Allgemeine Java-Themen 5
F Datum mit anzahl tagen berechnen Allgemeine Java-Themen 3
B Differenz in Monaten berechnen --- DateDiff()? Allgemeine Java-Themen 12
B Distance berechnen! Allgemeine Java-Themen 7
D Feiertage berechnen Allgemeine Java-Themen 8
F vergangene Zeit berechnen Allgemeine Java-Themen 6
R Zeitspannen berechnen Allgemeine Java-Themen 7
N 2 hoch 100 berechnen Allgemeine Java-Themen 8
P Punkt berechnen Allgemeine Java-Themen 4
C x-te Wurzel berechnen Allgemeine Java-Themen 2
M Formel in einem String während Laufzeit berechnen. Allgemeine Java-Themen 4

Ähnliche Java Themen

Neue Themen


Oben