Ermitteln aller perfekten Zahlen

Pupsicat

Mitglied
Hi Leutz,

versuche schon den halben Tag eine vollkommene Zahl zu bestimmen.
Vollkommene Zahl (auch perfekte Zahl) = Sie ist genauso groß wie die SUmme ihrer positiven
echten Teiler (außer sich selbst).
Z.B. 1+2+3 = 6
Formel: 2(hoch n-1)*(2 (hoch n) - 1)
bisher habe ich folgendes:

Java:
	public static void main(String[] args) {

		double x = 2;
		double result;
		for (int i=1;i<=100;i++){
			
			
			result= Math.pow(x,i-1)*(Math.pow(x,i)-1);
			
			System.out.println("result "+result); //Ausgabe zu Testzwecken
		}
		
		

	}


In der Ausgabe tauchen die perfekten Zahlen auf. Jetzt muss ich nur noch die Ausgabe auf dies Zahlen reduzieren. Mir kan gerade die Idee mit einer zweiten verschachtelten for und dem Modulo.
Weiss nur noch nicht wie ich das umsetzen soll.

Bitte keine Vollständigen Lösungen! Nur Lösungshinweise!
 

XHelp

Top Contributor
Du brauchst nur zu prüfen, ob
Code:
Math.pow(2d,i)-1
eine Primzahl ist...
 
Zuletzt bearbeitet:
G

Gast2

Gast
Ein Produkt zweier Zahlen (beide größer 1) kann keine Primzahl sein. Ne Prüfung würde da keinen sinn machen ;)
 

XHelp

Top Contributor
eine perfekte Zahl ist ja keine Primzahl. Alleine schon, weil die Summe der echten Teiler einer beliebigen Primzahl immer 1 ist.
Im Grunde musst du ja jetzt prüfen, ob die vermultich perfekte Zahl auch wirklich perfekt ist.
Das kannst du entweder:
in dem du alle echten Teiler aufsummierst: schleife von j=1 bis result-1: wenn result%j==0, dann ist das ein Teiler.
Aber ich glaub mich zu erinnern, dass die Euklidische Formel aufgeht, wenn
Code:
Math.pow(x,i)-1
eine Primzahl ist. Da kannst du es dann mit Miller-Rabin oder so überprüfen. Es könnte ggf. effizienter bei größeren Zahlen sein.
 

Pupsicat

Mitglied
Ich habe eine Denkblokade:
Java:
public static void main(String[] args) {

		double x = 2;
		double result;
		double rest;
		for (int i=1;i<=100;i++){
			result= Math.pow(x,i-1)*(Math.pow(x,i)-1);
			
			for(int j=1;j<=result-1;j++){
				if((result % j) == 0)
				System.out.println("ist echter Teiler ");
				else System.out.println("kein Teiler");
			}
			//System.out.println("result "+result); //Ausgabe zu Testzwecken
		}
		
		

	}

Ich weiss nicht recht ob der Gedanke mit der Verschachtelten Schleife so richtig ist.
Wo ist mein Fehler????:L
 

XHelp

Top Contributor
dann mach die sysouts weg, setzt die Summe rein, überprüf nach der inneren Schleife ob summe==result ist und wenn ja, gibt "summe" aus, ansonsten gar nichts... und dann lass es laufen.
 

Pupsicat

Mitglied
Ich hab Total die Denkblokade!;(

Kannst du bitte mein Code Ergänzen?
Danke!


Ich wollte zwar keine Lösung aber heute raff ich es nicht mehr!
 

XHelp

Top Contributor
Java:
double x = 2;
double result;
for (int i = 1; i <= 100; i++) {
	result = Math.pow(x, i - 1) * (Math.pow(x, i) - 1);
	System.out.println("DEBUG: "+i); //damit du siehst, dass es keine endlosschleife ist.
	int sum = 0;
	for (int j = 1; j <= result - 1; j++) {
		if ((result % j) == 0) {
			sum += j;
		}
	}
	if (sum == result) {
		System.out.println(sum);
	}
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
L Array: Summe aller geraden und ungeraden Zahlen ermitteln Java Basics - Anfänger-Themen 9
F wie kann ich die Position des letzten Vokals innerhalb einer Zeichenkette ermitteln? Java Basics - Anfänger-Themen 5
S Bildgröße ermitteln & setSize() übergeben Java Basics - Anfänger-Themen 6
B Anzahl Nullen uns Einsen in String ermitteln Java Basics - Anfänger-Themen 3
R Hangman-Spiel-zufälliges Wort ermitteln Java Basics - Anfänger-Themen 4
H Häufigkeit von Zahlen ermitteln Java Basics - Anfänger-Themen 23
H Palindrom ermitteln Java Basics - Anfänger-Themen 21
J Datum ermitteln ? Java Basics - Anfänger-Themen 14
M Beliebtesten Film ermitteln Java Basics - Anfänger-Themen 6
C Größte Zahl aus einem Array ermitteln(als statische Methode) Java Basics - Anfänger-Themen 31
H Bei forEach Index des Elements ermitteln Java Basics - Anfänger-Themen 17
B DHCP-Server Adresse ermitteln Java Basics - Anfänger-Themen 4
hello_autumn Klassen Anzahl sowie die Anzahl der Junit Tests ermitteln? Java Basics - Anfänger-Themen 8
J Ein Wort aus einer Datei zufällig ermitteln Java Basics - Anfänger-Themen 3
V Erste Schritte Potenzen b^n mittels Schleife ermitteln Java Basics - Anfänger-Themen 7
B Anzahl von Stunden / Tage von zwei Datumswerten ermitteln Java Basics - Anfänger-Themen 1
C Laufzeit eines Sortier-Algorithmus ermitteln Java Basics - Anfänger-Themen 4
O 2 Maximalwerte und Minimalwerte aus Array ermitteln Java Basics - Anfänger-Themen 9
L Fortschritt ermitteln Java Basics - Anfänger-Themen 18
N Erste Schritte HSV color space - schwarz und weiß nur anhand von Saturation oder Multiplikator ermitteln Java Basics - Anfänger-Themen 14
N Wahrscheinlichkeiten ermitteln Java Basics - Anfänger-Themen 2
L Objekt Typ zur Laufzeit ermitteln Java Basics - Anfänger-Themen 1
J Schwierigkeitsgrad eines Wortes mit Morsecode ermitteln Java Basics - Anfänger-Themen 18
J Best Practice Datum Differenz aus zwei Strings ermitteln Java Basics - Anfänger-Themen 8
M Erste Schritte primzahlen ermitteln, nur zahlen als eingabe erlauben Java Basics - Anfänger-Themen 34
G Größten und kleinsten Wert im Array ermitteln? Java Basics - Anfänger-Themen 7
G Wie kann ich diesen Wert ermitteln? Java Basics - Anfänger-Themen 4
T Rekursiv Tiefe eines binären Suchbaums ermitteln Java Basics - Anfänger-Themen 22
D Maximale Teilsumme ermitteln Java Basics - Anfänger-Themen 6
MiMa Jüngstes Datum ermitteln Java Basics - Anfänger-Themen 4
S Compiler-Fehler im array Maximum ermitteln Java Basics - Anfänger-Themen 6
V Querprodukt ermitteln Java Basics - Anfänger-Themen 6
Joew0815 Int to string und primzahle ermitteln Java Basics - Anfänger-Themen 2
F Jalousie Positionen ermitteln Java Basics - Anfänger-Themen 4
C Klassen aus einem Package ermitteln und per Laufzeit laden Java Basics - Anfänger-Themen 17
C Datei mit Daten einlesen und höchsten wert der zweiten Spalte ermitteln Java Basics - Anfänger-Themen 1
L Aus Datum Millisekunden ermitteln ohne Zeitzonen-Berücksichtigung Java Basics - Anfänger-Themen 6
C OOP Schwerpunkt eines Dreiecks ermitteln Java Basics - Anfänger-Themen 4
I Zeitraum eines Monats ermitteln und in String ausgeben Java Basics - Anfänger-Themen 1
S Datentypen Dimensionalität eines Arrays ermitteln Java Basics - Anfänger-Themen 2
V Anzahl von gleichen Werten in einem Int-Array ermitteln Java Basics - Anfänger-Themen 4
D TreeMap: Höheren Key ermitteln und den Value liefern Java Basics - Anfänger-Themen 3
J In einem Array die größte Zahl ermitteln und Faktorisieren. Java Basics - Anfänger-Themen 5
V Array ermitteln - in Quellcode speichern Java Basics - Anfänger-Themen 15
H JEditorPane: ermitteln, ob Zeichen unterstrichen Java Basics - Anfänger-Themen 4
M Monat der letzen 12 Monate ermitteln Java Basics - Anfänger-Themen 8
MiMa String Datum ermitteln Java Basics - Anfänger-Themen 9
H Veränderung eines Objekts ermitteln Java Basics - Anfänger-Themen 6
S Wochentage ermitteln Java Basics - Anfänger-Themen 5
S Ermitteln und Setzen der Attribute eines Objektes Java Basics - Anfänger-Themen 6
F Den Gewinner der Tordifferenz ermitteln Java Basics - Anfänger-Themen 5
J Eltern-Fenster ermitteln Java Basics - Anfänger-Themen 2
S MP3 Spielzeit mit jid3lib ermitteln? Java Basics - Anfänger-Themen 3
M Größer der eigenen .jar ermitteln Java Basics - Anfänger-Themen 4
M Größe einer Datei via. Link ermitteln Java Basics - Anfänger-Themen 9
R Alle Klassen ermitteln, die Interface implementieren / Reflection Java Basics - Anfänger-Themen 51
C Nächsten Montag ermitteln Java Basics - Anfänger-Themen 19
W Position in ArrayList ermitteln Java Basics - Anfänger-Themen 4
B Font Namen ermitteln Java Basics - Anfänger-Themen 7
C least significant bit einer HexMaske für Bitshift ermitteln Java Basics - Anfänger-Themen 2
B Pfad einer .jar im Programm ermitteln Java Basics - Anfänger-Themen 13
H "Index" eines Button ermitteln Java Basics - Anfänger-Themen 7
C Bereits geöffnetes Object ermitteln Java Basics - Anfänger-Themen 5
S ermitteln eines Wertes im StringArray Java Basics - Anfänger-Themen 4
D Ermitteln des kleinsten Messwertes von jedem Tag Java Basics - Anfänger-Themen 15
C Hösten Wert aus mehren Listen ermitteln Java Basics - Anfänger-Themen 2
D Input/Output Pfad richtig ermitteln Java Basics - Anfänger-Themen 12
P Dateigröße von Ordnern ermitteln Java Basics - Anfänger-Themen 8
T Enum - Key als Value ermitteln Java Basics - Anfänger-Themen 7
J den x und y Wert beim klicken der Maus ermitteln Java Basics - Anfänger-Themen 2
M float/double Anzahl Nachkommastellen ermitteln Java Basics - Anfänger-Themen 18
G Sekunden bis zum Ende der aktuellen Kalenderwoche ermitteln! Java Basics - Anfänger-Themen 3
F Substring mittels RegEx ermitteln/ersetzen? Java Basics - Anfänger-Themen 2
M Datentypen Generics: Exacten Typ ermitteln Java Basics - Anfänger-Themen 6
Spin Backgrond Color von Image ermitteln Java Basics - Anfänger-Themen 2
M Größe einer Konsole ermitteln Java Basics - Anfänger-Themen 2
c_sidi90 Größe von Dateien aus File Array ermitteln Java Basics - Anfänger-Themen 12
D Pfad zu "Eigenen Dateien" ermitteln Java Basics - Anfänger-Themen 8
A Relativer Pfad zu einem File ermitteln Java Basics - Anfänger-Themen 2
P Bestimmte Zeilen einer Datei ermitteln ? Java Basics - Anfänger-Themen 30
M Datentypen Wrapperclass eines Primitives ermitteln Java Basics - Anfänger-Themen 4
StrikeTom Shift + pfeiltaste ermitteln Java Basics - Anfänger-Themen 3
H Wie Projekt-Ordner-Pfad ermitteln? Java Basics - Anfänger-Themen 11
A Aktueller Pfad des Programms (.jar) ermitteln Java Basics - Anfänger-Themen 10
P Externe IP ermitteln? Java Basics - Anfänger-Themen 5
J Das Maximum einer Liste ermitteln Java Basics - Anfänger-Themen 8
S Klassennamen ermitteln Java Basics - Anfänger-Themen 10
R Stoppuhr: Zeit ermitteln und übergeben - Variable static?? Java Basics - Anfänger-Themen 6
T PixelFarbe ermitteln und in Fenster zeichnen Java Basics - Anfänger-Themen 12
W Average-Color (Durchschnittsfarbe eines Bildes ermitteln) Java Basics - Anfänger-Themen 16
D Ermitteln der Anzahl gleicher Nachkommastellen 2er Zahlen Java Basics - Anfänger-Themen 9
P Zeilenanzahl einer *.txt ermitteln Java Basics - Anfänger-Themen 6
B Teiler einer Zahl ermitteln Java Basics - Anfänger-Themen 12
H Dimensionen eines 2D-Arrays ermitteln Java Basics - Anfänger-Themen 5
Z Gesperrte JTable auslesen bzw feldposition ermitteln Java Basics - Anfänger-Themen 10
S Anzahl der Wochen eines Monats ermitteln Java Basics - Anfänger-Themen 19
F Hüllklassentyp einer Referenzvar ermitteln? Java Basics - Anfänger-Themen 3
G IP-Adresse ermitteln??? Java Basics - Anfänger-Themen 3
K Dateipfad ermitteln Java Basics - Anfänger-Themen 4
J OS Loginname ermitteln Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben