Sieb des Eratosthenes für Anfänger

m4libu17

Mitglied
Hi Leute,

zwecks Studium beschäftige ich mich seit 2 Monaten mit Java.
Nun ist die Aufgabe gestellt worden das Sieb des Eratosthenes zu programmieren, um damit alle Primzahlen bis zu einer einzugebenden Grenze zu finden.
Außerdem soll man noch die eingegebene Zahl in ihre Primzahlen zerlegen

An sich war das mit ein bisschen denken und rumprobieren nicht das großartige Problem das Sieb zum laufen zu bringen.

Das Problem ist nur dass das Ding effizient sein muss und ich hab echt keine Idee wie ich mein Sieb effizienter machen soll.

Ich hoffe ihr könnt mir helfen und schonmal danke im Vorraus :)

Hier mein Code:

Java:
public class Bsp07{
	public static void main(String[] args){
	
		int n = SavitchIn.readLineInt();             //mit der klasse SavitchIn wird eingelesen
		boolean[] liste = new boolean[n+1]; 
      boolean[] zerlegung = new boolean[n];
		int zeichenzaehler = 0;
		int a = 1, c = 1, k = 2;
		
		//liste markieren wenn nicht prim
		while(a < liste.length){
			if((a+1)%k == 0 && k < a+1){
            liste[a] = false;
            a++;
            k = 2;
         }
         else{
            if((a+1)%k == 0 && k >= a+1){
               a++;
               k = 2;
            }
            if((a+1)%k != 0 && k < a+1){
               liste[a] = true;
               k++;
            }
            
         }
		}	
		
      //ausgabe aller primzahlen, maximal 5 pro zeile
     	liste[1] = true;
      int b = 1;
		while(b < n){
			if(liste[b] == true)	{
				System.out.print((b+1)+" ");
				zeichenzaehler++;
		    if(zeichenzaehler%5 == 0)		
            System.out.print("\n");        
			}
         b++;
		}   
      
                                      
		//Primfaktorzerlegung von n
      int zaehler = 0;
		System.out.print("\n"+n+" = ");

		while(c < n){
         if(liste[c] == false){
            c++;
            continue;
         }
        	if((n%(c+1)) == 0){
           if(zaehler != 0)
             System.out.print(" * "+(c+1));
           if(zaehler == 0){
             System.out.print(c+1);
             zaehler++;
           }
			  n = n/(c+1);           
			}
         else
            c++;
		}
      System.out.print("\n");
	}
}
 
S

Spacerat

Gast
Das Thema gab's in diesem Forum schon öfters... Suchbegriffe "Erastothenes" und/oder "Pimzahl" in die SuFu gehackt sollten da bereits helfen.
Ansonsten... in einer Methode "isPrime(Number n)" kann man zwei Dinge von vorne herein ausschliessen:
1. "== 2" gibt true zurück
2. "% 2 || < 2" gibt false zurück.

Dann nimmt man von n die Wurzel als Obergrenze der Teiler und dann in einer Schleife:
Java:
for(int t = 3; t < Math.sqrt(n); t += 2) {
  if(n % t == 0) {
    return true;
  }
}
return false;
Wenn "isPrime()" true liefert, speicherst du die Zahl in einer Liste, bei false teilst du die Zahl durch die Werte in der Liste und prüfst erneut. Das ganze solange, bis das Teilergebnis selbst eine Primzahl ist.
Wenn mann's geschickt anstellt, geht das alles problemlos in einer einzigen Methode, denn eigentlich reichen als Teiler die Zahlen (Primzahlen) in der Liste völlig aus. Die Liste muss jedoch erst mal vorbefüllt sein (z.B. mit 2, 3, 5 und 7) und darf anschliessend keine Lücken aufweisen (also Primzahlen auslassen, z.B. auf die 7 muss die 11 und nicht die 13 folgen).
 

m4libu17

Mitglied
DAFUQ?
"In einer Methode kann man..."

Was für ne Methode?
Wie ich schon sagte...ich lern das seit Oktober und hab keine Ahnung von Methoden oder dergleichen.
Ich war bisher schon froh dass es ÜBERHAUPT n Ergebnis geliefert hat!
 
P

pappawinni

Gast
Wenn Sieb des Eratosthenes gefragt ist, sollte man das dann vielleicht auch machen.
Auch wenn andere Methoden vielleicht einfacher oder schneller sind...

Ich würd das vielleicht so lösen:
Java:
import java.util.ArrayList;

public class Bsp07 {
	 
    public static void main(String[] args) {
        
          int n=args.length==0? 100: Integer.parseInt(args [0]);

          ArrayList<Integer> primzahlen = eratosthenes(n);
          ArrayList<Integer> faktoren = new ArrayList<Integer>();
          int rest = n;
          int j;
          for (int i = 0;i < primzahlen.size(); i++){
        	  j = primzahlen.get(i);
        	  while (rest % j == 0){
        		  rest /= j;
        		  faktoren.add(j);
        	  }
        	  if (rest==1) break;
          }

          System.out.println("Primzahlen bis " + n);
          printList(primzahlen);
          
          System.out.println("Primfaktoren für " + n);
          printList(faktoren);

    }

    private static ArrayList<Integer> eratosthenes(int n){
        
        boolean[] gestrichen = new boolean[n-1];
        ArrayList<Integer> primes = new ArrayList<Integer>();
        for (int i = 2; i <= n; i++) {
        	gestrichen[i-2] = false;	
        }
        int q = (int) Math.sqrt(n);
        for(int i=2; i <= n; i++) {
            if (!gestrichen[i-2]) {
            	primes.add(i);
                if (i <= q) {
                    for (int j = i*i; j <= n; j+=i) {
                  	  if (j <= n) gestrichen[j-2]=true;
                    }
                }
            }
        }
        return primes;
    }

    private static void printList(ArrayList<Integer> intList) {
        int i=0;
        for (int entry:intList){
        	System.out.printf("%20d",entry);
        	i++;
        	if (i%5 == 0) System.out.println();
        }	        	
        System.out.println("\n");	    	
    }
}
 
Zuletzt bearbeitet von einem Moderator:

AmunRa

Gesperrter Benutzer
Nur so als NEbeninfo, für die tatsächliche implementierung des Siebes des Eratosthenes braucht man keine modulo rechnung.

Vl errinnert sich der eine oder andere daran, dass an das in der Volkschule oder halt in der 5 Schulstufe gelernt hat nur mit Zettel und Stift. Imprinzip ist das genau das was pappwini schon geschrieben hat, aber vl versteht man es so besser.

Code:
SChritt 1: BoolArray anlegen mit der Lenge n+1 nennen wir es notPrime (*) 
     alle Werte in diese Array sind nun false
Schritt 2: setze notPrime[0] = true;
Schritt 3: Wenn 1 als nicht als Primzahl zählt setze notPrime[1]= true
Schritt 4: 
  for ( int i=2;i<n+1/2;i++){
     if (!notPrime[i]){ //also wenn der Wert an dieser Stelle eine Primzahl ist
         for (int j=i+i;i<n+1;j=j+i){
              notPrime[j] = true;
         }
  }

SChritt 5 einmal durch das Array durch laufen und jede Stelle die false ist ist eine Primzahl und kann daher in eine Liste eingetragen werden.
(*) Ich nehme hier n+1 sodass die IndexPosition 3 auch tatsächlich die Zahl 3 meint und daher die Zahl n auch tatsächlich die Indexposition n hat.


Das ist der wirkliche Sieb des erathostenes Algorithmus und kommt vollständig ohne modulo Operation aus

Lg
AmunRa
 
P

pappawinni

Gast
Das Ganze mal mit Array statt Arraylist und als "all-in-one" Methode

Java:
    public static void main(String[] args) {
        
          int n = args.length==0 ? 100: Integer.parseInt(args [0]); //Liest Wert ein
          // Hier vielleicht noch eine Überprüfung, ob n im gültigen Bereich liegt

          // Eratosthenes
          boolean[] gestrichen = new boolean[n-1];
          int z = 0;
          for (int i = 2; i <= n; i++) {
          	gestrichen[i-2] = false;	
          }
          int q = (int) Math.sqrt(n);
          for(int i=2; i <= n; i++) {
              if (!gestrichen[i-2]) {
              	z++;
                  if (i <= q) {
                      for (int j = i*i; j <= n; j+=i) {
                    	  if (j <= n) gestrichen[j-2]=true;
                      }
                  }
              }
          }
          int[] primzahlen = new int[z];

          System.out.println("Primzahlen bis " + n);
          z=0;
          for(int i=2; i <= n; i++) {
              if (!gestrichen[i-2]) {
              	primzahlen[z]=i;         	
                z++;
            	System.out.printf("%20d",i);
            	if (z%5 == 0) System.out.println();
              }
          }
          System.out.println();
          
          // Primfaktoren , benutzt Ergebnis von Eratosthenes
          System.out.println("Faktoren für " + n);
          int rest = n;
          int j;
          z=0;
          for (int i = 0;i < primzahlen.length; i++){
        	  j = primzahlen[i];
        	  while (rest % j == 0){
        		  rest /= j;
        		  z++;
        		  System.out.printf("%20d",j);
        		  if ( z%5 == 0 ) System.out.println();
        	  }
        	  if (rest==1) break;
          }
          System.out.println();

    }
 
Zuletzt bearbeitet von einem Moderator:

m4libu17

Mitglied
ok ... ich hab keine ahnung was printf genau macht und habs dewegen einfach mal in ein normales print umgeformt ... das ausgabeformat ist ziemlich genau vorgegeben

aber der letzte code von pappawinni sieht doch schon für mich als anfänger sehr viel verständlicher aus.
was ich mich jetzt noch frage ist: wieso ist der code so viel leistungsstärker als meiner ... ich dachte wenn man schleifen in schleifen setzt dass das so viel leistung kostet?
 

AmunRa

Gesperrter Benutzer
Es geht bei pappawanis block nicht direkt um effizienz, sondern darum, dass das eine iplementierung des siebes des erath...
ist während dein Code dies nicht ist.

du verwendest zur untersuchung ob eine Zahl eine Primzahl ist die modulo Operation.


eine SChleife in einer Schleife muss nicht umbedingt langsamer sein.

Wenn ich z.B. mit deinm Algorithmus die schleifendurchläufe Zähle komme ich für n = 40 also alle ZAhlen bis 40 auf ueber 300 schleifen durchläufe, während bei pappas version die innerer SChleife nur 34 mal ausgeführt wird.

Das spricht für eine effizientere implementierung als deine ( DIe ich erhlich gesagt bis jetzt nicht verstanden habe).
 

m4libu17

Mitglied
wenn ich mir das so ansehe fällt der unterschied langsam auf ...

bei meinem Algorithmus wird jede (bzw jede zweite) zahl geprüft,
während bei pappawinni alle vielfachen einer bereits gefundenen Primzahl einfach übersprungen werden ... dass war eigentlich das was ich versucht habe... erfolglos

in diesem sinne danke ich euch für eure (erfolgreiche) Hilfe und dafür dass ihr mir meine fragen beantwprtet habt :)
 
P

pappawinni

Gast
printf ist halt gerade eben für die formatierte Ausgabe, aber das kannst du ja selbst googlen, oder?

in Kurzform:
der erste Parameter von printf ist der auszugebende Text, wobei Platzhalter eingebaut werden können.
Solche Platzhalter beginnen mit dem %-Zeichen..
"%20d" bedeutet halt, dass hier eine Zahl rechtsbündig in 20 Zeichen eingesetzt ausgegeben werden soll.
Für einzusetzende Werte müssen dann auch entsprechende Parameter in der erforderlichen Reihenfolge angegeben werden.
"%n" wäre eine Zeilenvorschub, wofür natürlich kein Parameter erforderlich ist.

Für weitere Erläuterungen hab ich jetzt leider keine Zeit.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
Zentriks Hilfe zu Sieb des Eratosthenes ohne boolean Java Basics - Anfänger-Themen 5
P Sieb des Eratosthenes Java Basics - Anfänger-Themen 9
S Hilfe bei "Sieb des Eratosthenes" mit Array & Markierung Java Basics - Anfänger-Themen 2
C Sieb des Eratosthenes ohne boolean Java Basics - Anfänger-Themen 20
I Sieb des Eratosthenes Java Basics - Anfänger-Themen 10
S Sieb des Eratosthenes Java Basics - Anfänger-Themen 5
P Sieb des Eratosthenes (bis 65536) Java Basics - Anfänger-Themen 8
H Sieb des Eratosthenes - Programmierfehler Java Basics - Anfänger-Themen 3
P BlueJ Sieb des Eratothenes Java Basics - Anfänger-Themen 4
T Erste Schritte Sieb des Eratothenes Java Basics - Anfänger-Themen 3
W Sieb des Erathostenes Java Basics - Anfänger-Themen 5
K need help doing Eratosthenes siev Java Basics - Anfänger-Themen 3
flatpat Variablen Eratosthenes mit Integer Array Java Basics - Anfänger-Themen 10
S Bitte Ratschläge für Console-MenuFührung... Java Basics - Anfänger-Themen 20
tomzen Java Unterstützung für exel dateien installieren. Java Basics - Anfänger-Themen 2
M Code aus IntelliJ in "Textform" für Word-Paper? Java Basics - Anfänger-Themen 10
G Icon für App Java Basics - Anfänger-Themen 1
Kerstininer Vererbung Hilfe beim lernen von Objektorientierung für eine Klausur Java Basics - Anfänger-Themen 10
Sniper1000 Java 391 für Windows Java Basics - Anfänger-Themen 37
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
benny1993 Java Programm erstellen für ein Fußball-Turnier Java Basics - Anfänger-Themen 3
V Durchschnittliche Volatility in Prozent für 4 Stunden berechnen Java Basics - Anfänger-Themen 14
P Welches SDK für das erstellen einer ausführbaren Datei? Java Basics - Anfänger-Themen 4
C negamax-Algorithmus für Tic-Tac-Toe spielt manchmal falsch Java Basics - Anfänger-Themen 10
D Apache HTTPClient für alle Fälle Java Basics - Anfänger-Themen 41
J Layout Manager, welcher ist der Richtige für mein Program? Java Basics - Anfänger-Themen 1
J Fehlermeldung unverständlich für Jakarta Java Basics - Anfänger-Themen 17
M Minimax-Algorithmus für Vier gewinnt Java Basics - Anfänger-Themen 11
M GUI für Vier-Gewinnt. Java Basics - Anfänger-Themen 4
I JPA Query für mehrere Klassen Java Basics - Anfänger-Themen 3
D Quellcode für cmd funktioniert nicht Java Basics - Anfänger-Themen 9
R Operatoren Rechenoperation in Java verwenden für Calculator Java Basics - Anfänger-Themen 2
R Operatoren Rechenoperation verwenden für Taschenrechner. Java Basics - Anfänger-Themen 32
Ostkreuz Counter für Booleanwerte Java Basics - Anfänger-Themen 8
B Regex Ausdrücke für Monate Java Basics - Anfänger-Themen 7
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
K loop pausieren für eine bestimmte Anzahl? Java Basics - Anfänger-Themen 1
Jxhnny.lpz Randomisier für Buttons Java Basics - Anfänger-Themen 13
W Intuitive interface für Komponenten Java Basics - Anfänger-Themen 4
M "Class<T> clazz" im Constructor - auch für int möglich? Java Basics - Anfänger-Themen 7
B Schrankensystem mit Farberkennung für Flashgame funktioniert nicht wie geplant Java Basics - Anfänger-Themen 4
I Code für Bezahlsystem (auch bei Offline Aktivität) Java Basics - Anfänger-Themen 7
U jUnit 5 Test für eine addMethode Java Basics - Anfänger-Themen 18
M monte carlo Algorithmus für 4 gewinnt Java Basics - Anfänger-Themen 12
frager2345 Java Singleton Muster -> Methode für Konstruktor mit Parametern Java Basics - Anfänger-Themen 3
izoards Sortier Algorithmus für Bounding Box Elememte Links nach Rechts und von Oben nach Unten Java Basics - Anfänger-Themen 33
M generate Methode für Streams Java Basics - Anfänger-Themen 6
I Datenmodell für "Tags" Java Basics - Anfänger-Themen 6
Lion.King for-Kontrollstruktur für Pyramide Java Basics - Anfänger-Themen 8
B Mit Countdown Midnestdauer für Teilaufgabenerledigung erzwingen Java Basics - Anfänger-Themen 8
J File length als Prüfwert für Download Java Basics - Anfänger-Themen 5
K Spieleidee gesucht für Informatikprojekt - JAVA (BlueJ)? Java Basics - Anfänger-Themen 15
P Zähler Variable für mehrere Objekte Java Basics - Anfänger-Themen 6
javamanoman Java für Online Banking Java Basics - Anfänger-Themen 12
NadimArazi Wie kann ich eine collision detection für die Paddles in meinem Pong Programm hinzufügen? Java Basics - Anfänger-Themen 4
JordenJost Java ist auch eine Insel für Anfänger Java Basics - Anfänger-Themen 2
P9cman Tipps für Rekursive Aufgaben mit Strings oder allgemein Java Basics - Anfänger-Themen 2
F Suche nach betreuender Person für eine Jahresarbeit der 12. Klasse. Java Basics - Anfänger-Themen 6
I SQL / JPA Query für StartDate und EndDate Java Basics - Anfänger-Themen 1
T getMethode für ein Array Java Basics - Anfänger-Themen 2
Fats Waller Farben mixen für den Hintergrund ? Java Basics - Anfänger-Themen 1
H Suche jemanden für kleine Uni-Abgabe/ mit Vergütung Java Basics - Anfänger-Themen 1
K Für was braucht man die left und right shift operatoren? Was bringen die, also welchen Zweck haben die? Java Basics - Anfänger-Themen 15
N Api nur für Textdatein (.txt) Java Basics - Anfänger-Themen 2
bluetrix Programmieren eines Bots für Zahlen-Brettspiel Java Basics - Anfänger-Themen 9
M Wie kann eine Methode für ein vorhandenes "Array von char" einen Index-Wert zurückliefern? Java Basics - Anfänger-Themen 3
R Ist Java das Richtige für mich? Java Basics - Anfänger-Themen 4
E Mittelquadratmethode für Hexadezimalzahlen Java Basics - Anfänger-Themen 1
P Einfacher regulärer Ausdruck (RegEx) für E-Mail-Adressen Java Basics - Anfänger-Themen 2
Kiki01 Wie würde eine geeignete Schleife aussehen, die die relative Häufigkeit für jeden Charakter in einem Text bestimmt? Java Basics - Anfänger-Themen 3
N Fehler im Code (Aufgabe für Anfänger) Java Basics - Anfänger-Themen 11
O Wie erstelle ich eine Instanz in einer Klasse für die ich die Instanz will? Java Basics - Anfänger-Themen 4
S BubbleSort für ArrayLists Java Basics - Anfänger-Themen 3
T Übungsbuch für Anfänger Java Basics - Anfänger-Themen 3
L Konzept für Quiz Java Basics - Anfänger-Themen 33
D Methoden Plathhalter für Integer in einer Methode Java Basics - Anfänger-Themen 19
B Datentyp für Einzelnes Objekt oder Liste Java Basics - Anfänger-Themen 9
D Welche GUI Library für eine Client Server Chat App Java Basics - Anfänger-Themen 14
T Algorithmus für Index mit min-Wert Java Basics - Anfänger-Themen 2
Aqtox Hallo ich muss für die Schule ein Wuerfell Duell erstellen jedoch habe ich ein fehler Java Basics - Anfänger-Themen 4
L loop für Namen Java Basics - Anfänger-Themen 11
kxrdelis Konstruktor für ein Rechtwinkliges Dreieck Java Basics - Anfänger-Themen 10
S Fehler bei Code mit SubStrings für mich nicht auffindbar. Java Basics - Anfänger-Themen 4
nevel Programm für die Summer der Zahlen 1- 1ß Java Basics - Anfänger-Themen 12
I Entity erstellen, die für API gedacht ist Java Basics - Anfänger-Themen 33
C Archiv für eigene Klassen Java Basics - Anfänger-Themen 9
A Junit Test für MysqlDataSource JDBC Java Basics - Anfänger-Themen 3
Animal-Mother BMI Rechner erstellen für W/M Java Basics - Anfänger-Themen 7
E Kleines Java-Projekt für Anfänger Java Basics - Anfänger-Themen 10
A Java die richtige Programmiersprache für mein Projekt? Java Basics - Anfänger-Themen 1
I DecimalFormat in Zahlenformat für Währung, habe 7,99, bekomme aber 7 Java Basics - Anfänger-Themen 4
L Methode für Zweidimensionale Arrays Java Basics - Anfänger-Themen 4
Kanaska Datentyp für Zahlenbereiche Java Basics - Anfänger-Themen 7
T Startbildschirm für ein Spiel erstellen Java Basics - Anfänger-Themen 0
U BestPractise für Deployment unter Windows gesucht Java Basics - Anfänger-Themen 12
lilrack UML Diagramm für Parkplatzverwaltung Java Basics - Anfänger-Themen 8
W Mehrfach das gleiche Attribut für ein Objekt erzeugen (mit verschiedenen Werten) Java Basics - Anfänger-Themen 2
B Generische Typen für dynamisches Formular Java Basics - Anfänger-Themen 3
C Was ist nötig für ein Java-Programm auf Server für Website Java Basics - Anfänger-Themen 18
T Vererbung Verschiedene Attribute für vererbte Klassen Java Basics - Anfänger-Themen 4

Ähnliche Java Themen


Oben