Perfekte Zahlen ausgeben

Tiny9014

Mitglied
Hallo, bin absoluter Anfänger und suche jemanden, der mir diesen Code erklärt. Also wie genau ein Ablauf aussieht. Leider konnte ich nichts passendes hier im Forum finden.

Code:
public class PerfekteZahl {

    public static void main(String[]args) {
       
        int teilersumme = 0;           
        int j = 1;
       
        while(j != teilersumme) {
           
            teilersumme = 0;
           
            for(int i = j / 2; i > 0; i-- ) {
                if(j % i == 0) {
                    teilersumme = teilersumme + i;
                }
            }
            if(teilersumme == j) {
                System.out.print(j + " = ");
               
                for(int i = j / 2; i > 0; i-- ) {
                    if(j % i == 0) {
                        teilersumme = teilersumme + i;
                        System.out.print(i);
                       
                        if(i != 1){
                            System.out.print(" + ");
                        }
                    }
                }
                System.out.println("");
            }
            j++;
        }
    }
}
 

httpdigest

Top Contributor
Ja genau... jetzt setzt sich hier gaaanz bestimmt jemand hin, und erklärt für dich Zeile für Zeile den Code, und warum er an jeder Stelle so funktioniert, wie er funktioniert.
Hast du mal daran gedacht, das selber zu versuchen? Bzw., woran scheitert es denn genau?
Ganz nebenbei: Die Aussage "Ich bin absoluter Anfänger, also kann ich das nicht" zählt hierbei nicht.
 

Tiny9014

Mitglied
Meine 1.Frage wäre schonmal, warum i=j/2 ist und nicht i=j und warum es i-- und nicht i++?
Danke für deine freundliche Art ;). Du wirst hier nicht gezwungen, zu antworten.
 

Javinner

Top Contributor
@Tiny9014
Operators
Java:
public class OperatorExample {

    public static void main(String[]args) {
       
        int key = 10;
        int lock = 10;
        System.out.println(key == lock ? Boolean.TRUE : Boolean.FALSE);
        int anotherLock = 11;
        System.out.println(key == anotherLock ? Boolean.TRUE : Boolean.FALSE);
    }
}
/** Output */
true
false
 

Meniskusschaden

Top Contributor
Meine 1.Frage wäre schonmal, warum i=j/2 ist und nicht i=j
j kann ja keinen Teiler haben, der größer als j/2 ist (außer sich selbst, was hier aber nicht erwünscht wäre).
und warum es i-- und nicht i++
Weil hier von j/2 bis 1 herunter gezählt wird, um alle Teiler-Kandidaten zu durchlaufen. Man hätte stattdessen auch von 1 bis j/2 herauf zählen können. Dann wäre i++ richtig gewesen.
 

Meniskusschaden

Top Contributor
Java:
while(j != teilersumme) {

teilersumme = 0;
Ebenfalls frage ich mich, was dies bezweckt.
Mit jeder Iteration der while-Schleife wird ein neues j als Kandidat dafür, eine perfekte Zahl zu sein, untersucht. Dafür muß die Teilersumme von j ermittelt werden, die deshalb zunächst auf 0 gesetzt wird, weil darin ja noch die Teilersumme des vorherigen Kandidaten abgelegt ist.
Die Bedingung der while-Schleife scheint aber noch nicht ganz ausgereift zu sein.
 

MoxxiManagarm

Top Contributor
j kann ja keinen Teiler haben, der größer als j/2 ist (außer sich selbst, was hier aber nicht erwünscht wäre).

Doch, eigentlich ist es erwünscht, wenn man es genau nehmen würde. Nach Definition gilt für eine eine Perfekte Zahl
3627e031c536dcff0b99eff7778e0ace371361bc
, inklusive der Zahl selbst. Für n=6 wäre die Summe Ihrerer Teiler inkl. sich selbst 1+2+3+6 = 12 = 2 * 6. 6 ist damit eine Perfekte Zahl. Abgeleitet von dieser Definition ist jedoch ist jedoch Die Summe der Teiler von n exklusive n damit n. Daraus kann man ableiten, dass der nächstekleiner Teiler von n nach n nur halb so groß wie n sein kann. Daher beginnt die Schleife bei n/2 - im Code ist n ein wachsendes j.
 
Zuletzt bearbeitet:

Meniskusschaden

Top Contributor
Doch, eigentlich ist es erwünscht, wenn man es genau nehmen würde. Nach Definition gilt für eine eine Perfekte Zahl
3627e031c536dcff0b99eff7778e0ace371361bc
, inklusive der Zahl selbst.
Na ja, es entspricht nicht so ganz meinem Verständnis von "eigentlich ist es erwünscht", wenn ich zwar bereits das richtige Ergebnis habe, aber trotzdem noch einmal denselben Aufwand investiere, um es zu verdoppeln, damit ich durch anschließende Division mit zwei doch noch das bereits zuvor bekannte Resultat erreiche.;)
Die Definitionen sigma(n) = 2n und sigma*(n) = n sind äquivalent, von daher würde ich ersteres nicht "die", sondern "eine" Definition nennen und die erste ist auch nicht "genauer" als die zweite.
 
X

Xyz1

Gast
Hi @Tiny9014 ;) Ma bisschen rum probiert:
Java:
public static void main(String[] args) {
    int k = 2;
    while (k < 90) {
        BigInteger l = BigInteger.valueOf(2).pow(k).subtract(BigInteger.ONE);
        if (l.isProbablePrime(1)) {
            System.out.println(k + ", " + BigInteger.valueOf(2).pow(k - 1).multiply(l));
        }
        k++;
    }
}

Die ersten 10 Zahlen:
Code:
2, 6
3, 28
5, 496
7, 8128
13, 33550336
17, 8589869056
19, 137438691328
31, 2305843008139952128
61, 2658455991569831744654692615953842176
89, 191561942608236107294793378084303638130997321548169216

Ich gehe davon aus dass es einfach keine ungeraden Zahlen gibt - und Euklid und Euler.... schon auch iewie schlau waren....

Meine Vermutung iss wenn Du k erhöhst erhöht sich dramatisch die Laufzeit. :eek::eek::eek:

@mihe7 Was wäre Dein Eindruck?:p
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
X Perfekte Zahlen mit Teiler ausgeben! Java Basics - Anfänger-Themen 29
S Die ersten vier perfekte Zahlen. Java Basics - Anfänger-Themen 30
L Perfekte Zahlen errechnen Java Basics - Anfänger-Themen 13
R Perfekte Zahl Java Basics - Anfänger-Themen 8
onlyxlia Anzahl Random Zahlen mit Scanner abfragen und in Array speichern Java Basics - Anfänger-Themen 10
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
P Aus Text Datei nur Zahlen übernehmen Java Basics - Anfänger-Themen 13
K Warum werden immer noch doppelte Zahlen ausgegeben ? Java Basics - Anfänger-Themen 13
M negative Zahlen bei Intervallen Java Basics - Anfänger-Themen 10
XWing Doppelte Zahlen im Array Java Basics - Anfänger-Themen 8
M 3 Zahlen miteinander vergleichen Java Basics - Anfänger-Themen 18
J Taschenrechner mit mehr als 2 Zahlen. Java Basics - Anfänger-Themen 18
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
B Alle Zahlen finden, die 3 bestimmte Ziffern enthalten? Java Basics - Anfänger-Themen 9
K Java gleicher Wert von Zahlen? Java Basics - Anfänger-Themen 5
I aus 2 random zahlen soll nur die ungerade summe der beiden genommen werden. Java Basics - Anfänger-Themen 13
J Operatoren Zahlen addieren Java Basics - Anfänger-Themen 13
B Threads Counter mit ungeraden Zahlen Java Basics - Anfänger-Themen 32
JavaBeginner22 Java 2 Zufalls zahlen generieren. Java Basics - Anfänger-Themen 11
X Wie kann man ein Regex erstellen, die 8-Bit-Binär-Zahlen darstellen. Java Basics - Anfänger-Themen 1
M Stream mit den ersten n natürlichen Zahlen Java Basics - Anfänger-Themen 4
D Größtes Palindrom Produkt aus zwei dreistelligen Zahlen Java Basics - Anfänger-Themen 60
T Methode, die prüft ob in einem Int-Array maximal 2 Zahlen enthalten sind, die größer als ihr Vorgänger sind Java Basics - Anfänger-Themen 5
sserio Befreundete Zahlen Java Basics - Anfänger-Themen 7
AhmadSlack Verzweigungen zahlen multiplizieren Java Basics - Anfänger-Themen 4
padde479 Array Multiplikation der ersten n Zahlen Java Basics - Anfänger-Themen 7
U Lotto-Zahlen App Java Basics - Anfänger-Themen 34
berserkerdq2 Wie würde man einen regulären Ausdruck in Java schreiben, der prüft, dass zwei bestimtme Zahlen nicht nebeneinadner sind? Java Basics - Anfänger-Themen 3
H Arrays: Größten Zahlen Unterschied herausfinden Java Basics - Anfänger-Themen 20
bluetrix Programmieren eines Bots für Zahlen-Brettspiel Java Basics - Anfänger-Themen 9
J Zahlen bis zu einem bestimmten Grenzwert ausgeben Java Basics - Anfänger-Themen 11
00111010101 Objektorientiertes Programmieren mit Vererbung (Zahlen in Array verschwinden) Java Basics - Anfänger-Themen 3
P Zweidimensionales Array als Tabelle mit befüllten Zahlen Java Basics - Anfänger-Themen 10
W Wie ziehe ich von einer bestimmten Zahl, Zahlen ab, bis mein Ergebnis null beträgt? Java Basics - Anfänger-Themen 10
emx-zee Erste Schritte NullPointerException, Array mit zufälligen Zahlen füllen Java Basics - Anfänger-Themen 2
W Bestimmte Zahlen bei Math.random ausschließen? Java Basics - Anfänger-Themen 31
K Erste Schritte "Taschenrechner" zeigt keine Komma Zahlen an. Java Basics - Anfänger-Themen 8
P Drei Zahlen eines Würfelspiels auswerten Java Basics - Anfänger-Themen 7
H Häufigkeit von Zahlen ermitteln Java Basics - Anfänger-Themen 23
sashady Zahlen rekursiv zerlegen und Ziffern addieren Java Basics - Anfänger-Themen 38
H Zahlen kürzen Java Basics - Anfänger-Themen 2
ansystin Teilerfremde Zahlen ausgeben + Zahlenausgabe speichern Java Basics - Anfänger-Themen 3
B Häufigkeit einzelner Zahlen in einem Array Java Basics - Anfänger-Themen 6
nevel Programm für die Summer der Zahlen 1- 1ß Java Basics - Anfänger-Themen 12
jhCDtGVjcZGcfzug Fibonacci Zahlen rekursiv und iterativ Java Basics - Anfänger-Themen 21
H Eingegebene Zahlen mit Array ausgeben Java Basics - Anfänger-Themen 18
I 12 Spalten von jeweils 30 Zahlen in Konsole ausgeben Java Basics - Anfänger-Themen 6
R Array mit Unter- und Obergrenze ganze Zahlen dazwischen erscheinen nicht Java Basics - Anfänger-Themen 1
OZAN86 For Schleife von 1-50 die Zahlen werden durch ein Komma getrennt Java Basics - Anfänger-Themen 10
Bademeister007 Operatoren Alle Zahlen einer ArrayList die durch 5 teilbar ist Java Basics - Anfänger-Themen 2
mhmt_03 dafür sorgen, dass im JTextfield nur zahlen eingebbar sind Java Basics - Anfänger-Themen 9
Ianatrix Zahlen von a bis b berechnen Java Basics - Anfänger-Themen 7
P Wie kann ich die Zahlen dieses Arrays dividieren? Java Basics - Anfänger-Themen 2
P Nutzer entscheiden lassen, wie viele Zahlen dieser in ein Array eingeben möchte. Java Basics - Anfänger-Themen 6
T Bestimmte Zahlen ausgeben mit einer whilfe Schleife Java Basics - Anfänger-Themen 21
H Alle Geraden zahlen bis 10 ausgeben Java Basics - Anfänger-Themen 11
java3690 Liste mit zufälligen zahlen füllen Java Basics - Anfänger-Themen 27
macle Rekursive String Methode, Gerade Zahlen rausfiltern Java Basics - Anfänger-Themen 10
M Regex nur Zahlen und Punkt zulassen, Keine Eingabe(Leeres TextFeld) nicht zulassen Java Basics - Anfänger-Themen 6
L Mit Zahlen im String rechnen Java Basics - Anfänger-Themen 19
G Java eingelesene Zahlen Java Basics - Anfänger-Themen 2
D Zahlen werden falsch gekürzt :? Java Basics - Anfänger-Themen 27
H Ungerade Zahlen ausgeben von 1 bis 1000 Java Basics - Anfänger-Themen 8
C Positive und negative Zahlen mit Regex extrahieren Java Basics - Anfänger-Themen 8
N Wörter und Zahlen nach speziellen Wörtern ausgeben Java Basics - Anfänger-Themen 11
F Komplexe Zahlen auf verschiedene Weise addieren Java Basics - Anfänger-Themen 18
L Java Int-Array, Zahlen sortieren Java Basics - Anfänger-Themen 8
B Fibonacci Zahlen dynamische Programmierung Java Basics - Anfänger-Themen 7
V Erste Schritte Taschenrechner mit beliebig vielen Zahlen Java Basics - Anfänger-Themen 5
X Wie kann ich Zahlen in einzelne Zifferne zerlegen? Java Basics - Anfänger-Themen 3
J 10 positive Zahlen eingeben Java Basics - Anfänger-Themen 10
K Rechtsbündige Ausgabe von Zahlen Java Basics - Anfänger-Themen 6
A Wie zwei zahlen in einer Variable speichern? Java Basics - Anfänger-Themen 7
M Zahlen erraten Java Basics - Anfänger-Themen 7
E Zahlen von einem Array mit zahlen von zweitem Array vergleichen Java Basics - Anfänger-Themen 27
S Mit nextGaussian() positive Zahlen erzeugen? Java Basics - Anfänger-Themen 39
D auch negative Zahlen sotieren Java Basics - Anfänger-Themen 18
M Warum berechnet mein Primzahlenprog zu hohe Zahlen nicht? Java Basics - Anfänger-Themen 20
W Bell Zahlen Java Basics - Anfänger-Themen 2
H Min und Max von Zahlen Java Basics - Anfänger-Themen 10
der_Schokomuffin Fehler bei Zufallsgeneration von Zahlen Java Basics - Anfänger-Themen 7
J Erste Schritte Alle möglichen ausgaben von 5 Zahlen als Vector Java Basics - Anfänger-Themen 7
F Abstand zum Durchschnitt von 5 Zahlen berechnen... Java Basics - Anfänger-Themen 16
Moji Klassen Array Zahlen zu Sternchen (U-Helmich 7.1-4) Java Basics - Anfänger-Themen 5
F Summe aller echten Teiler und Zahlen zurückgeben Java Basics - Anfänger-Themen 1
F Zahlen im Feld sortieren + Unterprogramm Java Basics - Anfänger-Themen 4
H Zahlen 1-100 Java Basics - Anfänger-Themen 2
H Einlesen von Zahlen Java Basics - Anfänger-Themen 20
O Problem gleiche Zahlen Java Basics - Anfänger-Themen 2
V Hilfe Aufgabe Zahlen Java Basics - Anfänger-Themen 9
J Zahlen addieren Java Basics - Anfänger-Themen 12
P Schlüsselworte Zählen und Zuweisen von eingelesenen Zahlen Java Basics - Anfänger-Themen 1
D Irgendwelche Ideen um Zahlen Reihenfolgen zu analyisieren Java Basics - Anfänger-Themen 16
CptK Datentypen Zahlen Java Basics - Anfänger-Themen 2
B Wie kann ich die Buchstaben sortieren nach der Höhe der Zahlen Java Basics - Anfänger-Themen 14
Y kann jemand die Terme mit Zahlen schreiben ?? Java Basics - Anfänger-Themen 4
A Ein Array mit zufälligen Zahlen füllen Java Basics - Anfänger-Themen 4
E LMC (Assembler) Sortieren von 3 Zahlen Java Basics - Anfänger-Themen 4
x-tshainge Zahlen Buchstaben zuordnen Java Basics - Anfänger-Themen 4
F Zahlen aus Datei einlesen und in Array speichern Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben