Perfekte Zahlen errechnen

Lybrial

Bekanntes Mitglied
Hiho,

bin seid einigen Stunden mit einem Problem beschäftigt und zwar bekomme ich es nicht
hin auf korrekte Weise alle Teiler einer perfekten Zahl auszugeben bzw. diese auch vorher
erst zu testen, ob sie denn perfekt ist.
Ein Zahl ist dann perfekt, wenn die Summe all ihrer Teiler die kleiner als
sie sind, die Zahl selber ergibt.

Bsp: 6 ist perfekt weil: 3+2+1 = 6

bisheriger Code:

Java:
import java.util.Scanner;
public class Aufgabe4
{
	public static void main(String[] args)
	{
		Scanner input = new Scanner(System.in);
		
		int zahl;
		int summe = 0;
		int teiler = 0;
		
		System.out.print("Bitte eine Ganzzahl eingeben: ");
		zahl = input.nextInt();
		
		for(int i = zahl; i > 1; i--)
		{
			for(teiler = 2; (teiler*teiler) < zahl; teiler++)
			{
				if(zahl % teiler == 0)
				{
					summe = summe + (zahl/teiler);
				}
				if(summe == zahl)
				{
					System.out.println(" " +i+ " ist eine perfekte Zahl!");
					summe = 1;
				}
			}
		}
	}
}
 

XHelp

Top Contributor
Ist das ein Blog-Eintrag, oder fehlt hier die Frage? ;)
Außerdem habe ich ein Deja-vu... das gleiche Thema kam schon vor ein paar Tagen, einfach mal dannach suchen, ist bestimmt ein Kommilitone von dir :)
 

Landei

Top Contributor
Du brauchst nicht rumzuprobieren, damit kommst du nicht weit. z ist dann und nur dann eine perfekte Zahl wenn z = 2^(n - 1) * (2^n - 1) und (2^n - 1) eine Primzahl ist (für letzteres muss n selbst eine Primzahl sein).

Vollkommene Zahl ? Wikipedia

Java:
import java.math.BigInteger;

public class PerfectNumber {

    public static BigInteger perfectNumber(int n) {
        BigInteger prime = BigInteger.valueOf(2).pow(n).subtract(BigInteger.ONE);
        return prime.isProbablePrime(20)
                ? prime.multiply(BigInteger.valueOf(2).pow(n-1))
                : null;
    }

    public static void main(String[] args) {
        for (int n = 1; n < 100; n++) {
            if (BigInteger.valueOf(n).isProbablePrime(20)) {
                BigInteger bi = perfectNumber(n);
                if (bi != null) {
                    System.out.println("n=" + n + ", perfect number:" + bi);
                }
            }
        }
    }
}

Code:
n=2, perfect number:6
n=3, perfect number:28
n=5, perfect number:496
n=7, perfect number:8128
n=13, perfect number:33550336
n=17, perfect number:8589869056
n=19, perfect number:137438691328
n=31, perfect number:2305843008139952128
n=61, perfect number:2658455991569831744654692615953842176
n=89, perfect number:191561942608236107294793378084303638130997321548169216
 

Lybrial

Bekanntes Mitglied
Das Programm kann ich noch nicht^^

Er gibt bei mir halt garnichts aus, eigentlich müsste es doch so funktionieren:

Java:
import java.util.Scanner;
public class Aufgabe4
{
	public static void main(String[] args)
	{
		Scanner input = new Scanner(System.in);
		
		int zahl;
		int summe = 0;
		int teiler;
		
		System.out.print("Bitte eine Ganzzahl eingeben: ");
		zahl = input.nextInt();
		
		for(int i = zahl; i > 1; i--)
		{
			for(teiler = 2; teiler < i; teiler++)
			{
				if(i % teiler == 0)
				{
					summe = summe + (i/teiler);
				}
			}
			if(summe == i)
			{
				System.out.println(" " +i+ " ist eine perfekte Zahl!");
			}
		}
	}
}
 

energy47

Mitglied
hier meine lösung..

Java:
import java.util.Scanner;

public class CPerfekteZahl {

	public static void main(String[] args) {

		int zahl = 0;
		int summe = 0;

		Scanner sc = new Scanner(System.in);
		System.out.println("geben sie eine zahl ein: ");
		zahl = sc.nextInt();

		for (int i = 1; i < zahl; i++) {
			if (zahl % i == 0) {
				summe += i;
			}
		}
		if (summe == zahl)
			System.out.println("die " + zahl + " ist eine Perfekte zahl");

		else
			System.out.println("leider keine perfekte zahl");
	}
}

ist nur gut wenn man selbst eine zahl eingibt.. man kann da auch eine schleife drum herum bauen um einfach zahlen von 1 bis n durch zu probieren aber das kann sehr sehr lange dauern.. dafür ist die lösung von landei besser
 

Lybrial

Bekanntes Mitglied
ah hatte ich vergessen zu erwähnen, wenn ich nur sagen möchte
ob eine zahl perfekt ist oder nicht, krieg ich das hin, was ich nicht
hinbekomme ist, dass jeder teiler der perfektenzahl ausgegeben wird.
 

energy47

Mitglied
Das Programm kann ich noch nicht^^

Er gibt bei mir halt garnichts aus, eigentlich müsste es doch so funktionieren:

Java:
import java.util.Scanner;
public class Aufgabe4
{
	public static void main(String[] args)
	{
		Scanner input = new Scanner(System.in);
		
		int zahl;
		int summe = 0;
		int teiler;
		
		System.out.print("Bitte eine Ganzzahl eingeben: ");
		zahl = input.nextInt();
		
		for(int i = zahl; i > 1; i--)
		{
			for(teiler = 2; teiler < i; teiler++)
			{
				if(i % teiler == 0)
				{
					summe = summe + (i/teiler);
				}
			}
			if(summe == i)
			{
				System.out.println(" " +i+ " ist eine perfekte Zahl!");
			}
		}
	}
}


dein programm macht nicht das was die regeln verlangen..
 

Landei

Top Contributor
teiler muss bei 1 anfangen. Übrigens sind perfekte Zahlen immer gerade (es ist zwar nicht bewiesen, dass es keine ungeraden gibt, aber das erste Gegenbeispiel müsste astronomisch groß sein)

Das Programm kann ich noch nicht^^

Das Programm ist nicht kompliziert, es sieht nur durch die umständliche BigInteger-Syntax so aus. Man kann die BigIntegers z.b. durch longs ersetzen (und add durch +, multiply durch * u.s.w.), das Problem ist nur, dass die perfekten Zahlen so schnell größer werden, dass man so nur wenige erwischt, bevor sie zu groß werden.

OT: Da das ein gutes Beispiel ist, wie man die umständliche Syntax vereinfachen kann, habe ich es ins Wiki meiner BigInt-Bibliothek BIRPN gepackt: RefactoringExample - birpn - A small example how to introduce BIRPN - Project Hosting on Google Code
 
Zuletzt bearbeitet:

Lybrial

Bekanntes Mitglied
Java:
import java.util.Scanner;
public class Aufgabe4
{
	public static void main(String[] args)
	{
		Scanner input = new Scanner(System.in);
		
		int n;
		int summe = 0;
		
		System.out.print("Bitte eine Ganzzahl eingeben: ");
		n = input.nextInt();
		
		for(int j = n; j > 1; j--)
		{
			summe = 0;
			for(int i = 1; i <= j; i++)
			{
				if(j%i == 0)
				{
					summe = summe + i;
				}
				if(summe == j)
				{
					System.out.println("Die Zahl: " +j+ " ist eine perfekte Zahl!");
				}
			}
		}
	}
}

Die zahlen stimmen so weit AUßER!!!
Warum zeigt er mir hier die 24 als perfekte Zahl an? das ist falsch.
6 und 28 und 496 etc. werden angezeigt und sind auch korrekt.
aber wie kommt der auf die 24? versteh ich nicht.

und warum gibt er mir das auch mehrmals aus?
 

Clahboid

Mitglied
Hi,

Du darfst die Ausgabe erst nach der for-Schleife ausführen. Jetzt rechnet er bei 24:
1+2+3+4+6+8=24 -> Ausgabe
Dann wird die 9 überprüft. Ist kein Teiler. Also bleibt Summe bei 24. Also Ausgabe. Dasselbe bei 10 und 11. Erst bei 12 ändert sich wieder die Summe.

Also erst alle Teiler aufsummieren und dann die Überprüfung und Ausgabe.
 

Lybrial

Bekanntes Mitglied
Java:
import java.util.Scanner;
public class Aufgabe4
{
	public static void main(String[] args)
	{
		Scanner input = new Scanner(System.in);
		
		int n;
		int summe = 0;
		
		System.out.print("Bitte eine Ganzzahl eingeben: ");
		n = input.nextInt();
		
		for(int j = n; j > 1; j--)
		{
			summe = 0;
			for(int i = 1; i < j; i++)
			{
				if(j%i == 0)
				{
					summe = summe + i;
				}
				if(summe > n)
				break;
			}
			if(summe == j)
			{
					System.out.println("Die Zahl: " +j+ " ist eine perfekte Zahl!");
			}
		}
	}
}

Danke, funzt :D
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
T Perfekte Zahlen ausgeben Java Basics - Anfänger-Themen 12
S Die ersten vier perfekte Zahlen. Java Basics - Anfänger-Themen 30
X Perfekte Zahlen mit Teiler ausgeben! Java Basics - Anfänger-Themen 29
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