Primzahlen in Java berechnen...
-
Hallo
Vor etwa 15 MInuten hat mich eine Freundin gefragt, wie folgende Aufgabe geht.
Ich hab mir gedacht okee, ist kein Problem. Nur leider hab ich mir dann eingestehen müssen, das ich keinen blassen Schimmer davon habe4 Uebung 4.3: Primteiler
Erstellen Sie eine Applikation `Prim', die fur eine positive ganze Zahl n
den kleinsten Primfaktor berechnet.
Algorithmus:
Durchlaufen Sie die Werte p = 2; 3; 5; 7; : : : , bis n durch p teilbar ist,
oder p > n ist. Im zweiten Fall ist n eine Primzahl.Ich rall die Aufgabe sowas von nicht. Kann mir da jemand mal etwas helfen? Die Aufgabe ist ja eigentlich voll schlecht geschireben, denn man muss ja erstmal noch herausfinden, ob die Zahl eine Primzahl ist, wenn man iteriert mit ner schlaufe :S
gruss
-
Der beschriebene Algorithmus soll die Primzahl-Erkennung sein, wobei es ausreicht, bis n/2 zu iterieren.
Um die Primfaktoren zu erhalten, muß man dann jeweils die größte Primzahl ermitteln, du die die Zahl teilbar ist und dann entsprechend weitermachen, bis man alle Faktoren zusammen hat.
z.B.
30 = 5 * 3 * 2also erstmal alle Primzahlen bis 30 ermitteln (bzw. vorab in einer Tabelle ablegen und nachschauen), also 2, 3, 5, 7, 11, 13 (mehr braucht man nicht, da man nur die Primzahlen bis 30/2 = 15 benötigt, denn 30 kann ja nicht mehr durch 17 teilbar sein).
Nun die Liste von oben herab überprüfen, ob der Wert ganzzahlig teilbar ist (also 30 mod x == 0).
So erhält man zuerst 5, dann teilt man 30 durch 5 und erhält 6 und nun sucht man alle Primfaktoren für diese Zahl und erhält analog die 3 und dann abschließend die 2.
Nun dies nur noch in Java umsetzen...
-
Th schrieb:
Der beschriebene Algorithmus soll die Primzahl-Erkennung sein, wobei es ausreicht, bis n/2 zu iterieren.
Es reicht sogar aus, bis sqrt(n) zu gehen.
-
Gregor schrieb:
Th schrieb:
Der beschriebene Algorithmus soll die Primzahl-Erkennung sein, wobei es ausreicht, bis n/2 zu iterieren.
Es reicht sogar aus, bis sqrt(n) zu gehen.
hm wie darf ich das verstehen? ich hab vor 2 jahren mal java für 3 wochen angeschaut und hab keine ahnung davon. progge nur c / c++ und php
hat nicht java soviele math funktionen?
-
OK, für die Primzahl-Erkennung reicht sqrt(n) aus, aber für die Primfaktorenzerlegung nicht, z.B. 22 = 11 * 2, während sqrt(22) = 4,69...
-
Th schrieb:
OK, für die Primzahl-Erkennung reicht sqrt(n) aus, aber für die Primfaktorenzerlegung nicht, z.B. 22 = 11 * 2, während sqrt(22) = 4,69...
Ach so meintest Du das. Ja, stimmt wohl, wenn man so vorgeht.
-
Wie es aus der Aufgabe ersichtlich ist wird nach den kleinsten Primfaktor gesucht also reicht sqrt(n) aus.
Auch bei einer trivialen iterativen Primfaktorzerlegung ist eine Grenze von sqrt(n) sinnvoll.
-
aber wenn man 22 in primfaktoren zerlegen will, kommt man ja zwangsläufig auf 22=11*2; und 11>sqrt(22); Also ist doch die Grenze n/2 sinvoller?!
Beste Grüße
Jan
-
LeGaN schrieb:
aber wenn man 22 in primfaktoren zerlegen will, kommt man ja zwangsläufig auf 22=11*2; und 11>sqrt(22); Also ist doch die Grenze n/2 sinvoller?!
Schreib mal nen kurzen Pseudocode, wie Du eine Zahl in Primfaktoren zerlegen würdest. Bei mir würde das etwa so aussehen:
getPrimfaktoren (zahl) { für (alle Primzahlen p bis einschließlich sqrt(zahl)) { wenn (zahl durch p teilbar ist) { return p und getPrimfaktoren(zahl/p); } } return zahl; }
...da gäbe es also tatsächlich keinen Grund, bis zahl/2 zu gehen, aber man kann da natürlich auch anders vorgehen.
-
Jepp genau. War gestern nur zu faul es detaillierter wieder zugeben.
Und die Primzahlen bis sqrt(n) kann er mit den Sieb des Eratosthenes bestimmen.
So kann sich deine Freundin noch ein paar +Punkte beim Prof. holen.
Beispielcode sollte im Netz genug zu finden sein einfach mal googeln.Cu
Marcel
-
ähm bin ich der einzige, der davon ausgeht, dass mit "p = 2; 3; 5; 7; : : :" eigentlich "p = 2; 3; 5; 7; 9; 11; 13; 15; .." gemeint ist und nicht "p = 2; 3; 5; 7; 11; 13; 17;.."? So macht die Aufgabe ihmo viel mehr Sinn
-
Nein! Du bist nicht der Einzige.
Es war sicherlich gemeint: 2, 3, 5, 7, 9, ...
-
Ähm dann bist du wenigstens nicht der Einzigste der falsch liegt.
9 ist ein Vielfaches von 3 und somit sind alle Vielfachen von 9 auch Vielfache von 3. Somit erübrigt sich auch der Test mit 9. etc.Gruss
Marcel
-
Ich bin niemals der Einzig st e!
-
Nachtrag:
Es wird in der Aufgabe nach den kleinsten Primfaktor gesucht!
9, 15 sind keine Primfaktoren!
-
grenouille_unreg schrieb:
Somit erübrigt sich auch der Test mit 9. etc.
Sicher! Nur, wie willst du das coden?
boolean prim(int n) { if (n <= 2) return n==2; int limit = (int) sqrt(n); for (int j=2; j <= limit; ++j) if (prim(j) && n%j == 0) return false; return true; }
ist ja nicht besonders effizient!
Ein solcher Algorithmus macht nur Sinn bei Sprachen
die Lazy-Evaluation anbieten und ist fernab der
Aufgabenstellung (zu komplex).
-
grenouille_unreg schrieb:
9, 15 sind keine Primfaktoren!
Und woher weißt du das?
Gib's zu: Bei deiner oben angegebenen Aussage hast du
bereits gewußt, daß 9 durch 3 teilbar ist.
-
Es war ein minimalistisches Lemma, das jeder mit einen gesunden Menschenverstand kapiert hätte. Du denkst zu java-mäßig. Es ging darum den Fragenden Lösungsansätze anzubieten, ohne auf irgendwelche Implementierungdetails und Komplexitätsbetrachtungen einzugehen. Da es Erstens zu weit führen würde und Zweitens findet man zieml. viel über die Thematik im Netz. Es war nur ein Denkanstoss.
-
nonN schrieb:
4 Uebung 4.3: Primteiler
Erstellen Sie eine Applikation `Prim', die fur eine positive ganze Zahl n
den kleinsten Primfaktor berechnet.
Algorithmus:
Durchlaufen Sie die Werte p = 2; 3; 5; 7; : : : , bis n durch p teilbar ist,
oder p > n ist. Im zweiten Fall ist n eine Primzahl.Das war die Aufgabenstellung.
Und bei dieser Aufgabenstellung erübrigen sich eigentlich alle
Fachsimpeleien (testen bis n/2 oder sqrt(n), nur durch Primzahlen teilen,..)Insofern ist dieser Thread ziemlich abschweifend geworden.
-
Es ist nirgends geschrieben, dass p eine Primzahl sein soll. Weiter ist das imho nicht sinnvoll. Also bin ich verwundert, dass hier jeder annimmt, dass p eine Primzahl sein soll.
Btw. wäre der Algorithmus für meine Folge selbstverständlich auch richtig (und wesentlich effizienter)...