Abundante Zahlen

cs1305

Mitglied
Hallo Leute,

ich studiere Wirtschaftsingenieurwesen und schreibe in der kommenden Woche eine Wiinfo Klausur. Bei der letzten Altklausur sollten wir im Java Teil ein kleines Programm schreiben. Da keine Lösung raus gegeben wurde und ich selbst nicht auf ein funktionierendes Programm komme wollte ich euch um Hilfe bitten.

Und zwar geht es um eine mathematische Eigenschaft :

Eine natürliche Zahl heißt abundant (lat. abundans „überladen“), wenn ihre echte Teilersumme (die Summe aller Teiler ohne die Zahl selbst) größer ist als die Zahlselbst.

Bei der Zahl 12 wären die Teiler 6,4,3,2,1 und damit in der Summe größer als die Zahl selbst.

Die Aufgabenstellung war: Schreibe ein Programm, dass alle Zahlen von 1-100 darauf prüft, ob sie abundant sind oder nicht. Alle abundanten Zahlen, als auch alle nicht abundanten Zahlen sollten mit einem Text auf der Konsole ausgegeben werden.

Habt ihr Ideen ?

Wäre euch total dankbar.
 

Joose

Top Contributor
Wo genau liegt dein Problem? Bei der Überprüfung ob eine Zahl abundant ist?
Wie würdest du es denn mit Zettel+Stift machen?

Schreibe eine Methode welche prüft ob eine Zahl "abundant" ist, in der main-Methode musst du nur noch eine Schleife schreiben welche die Methode aufruft und dir entsprechende Ergebnisse liefert (welche du dann ausgibst).
 

tommysenf

Top Contributor
Java:
public class Abundanz
{
  public static void main(String[] args)
  {

    for (int i=1; i <= 100; i++) {
       System.out.println(i + " " +  istAbundant(i));
    }
  }
 
  static int berechneTeilerSumme(int a) {
 
       int summe = 0;
       for (int teiler=1; teiler < a; teiler++) {
         if (a % teiler == 0) {
           summe += teiler;
         }
       }
       return summe;
  }
 
  static boolean istAbundant(int i) {
      return berechneTeilerSumme(i) > i;
  }
 
}
 
X

Xyz1

Gast
Mach mal einen Wettbewerb draus.
Ich habe mir das hier durchgelesen:
https://ktrobotics.wordpress.com/2015/09/06/java-example-finding-abundant-numbers/
https://stackoverflow.com/questions/8647059/finding-factors-of-a-given-integer
und
https://de.wikipedia.org/wiki/Abundante_Zahl

Ich bin der Meinung, das sei schnell:
Java:
    static boolean abu(int i) {
        /*
        if (i < 12) {
            return false;
        }
        if (i < 945 && i % 2 != 0) {
            return false;
        }
        */
        int sum = 1;
        for (int j = i / 2; j > 1; j--) {
            if (i % j == 0) {
                sum += j;
                if (sum > i) {
                    return true;
                }
            }
        }
        return false;
    }

(Ja, das funktioniert auch mit 0.)
Java:
        for (int j = 0; j < 1511; j++) {
            if (abu(j)) {
                System.out.print(j + ", ");
            }
        }

Ausgabe:
Code:
12, 18, 20, 24, 30, 36, 40, 42, 48, 54, 56, 60, 66, 70, 72, 78, 80, 84, 88, 90, 96, 100, 102, 104, 108, 112, 114, 120, 126, 132, 138, 140, 144, 150, 156, 160, 162, 168, 174, 176, 180, 186, 192, 196, 198, 200, 204, 208, 210, 216, 220, 222, 224, 228, 234, 240, 246, 252, 258, 260, 264, 270, 272, 276, 280, 282, 288, 294, 300, 304, 306, 308, 312, 318, 320, 324, 330, 336, 340, 342, 348, 350, 352, 354, 360, 364, 366, 368, 372, 378, 380, 384, 390, 392, 396, 400, 402, 408, 414, 416, 420, 426, 432, 438, 440, 444, 448, 450, 456, 460, 462, 464, 468, 474, 476, 480, 486, 490, 492, 498, 500, 504, 510, 516, 520, 522, 528, 532, 534, 540, 544, 546, 550, 552, 558, 560, 564, 570, 572, 576, 580, 582, 588, 594, 600, 606, 608, 612, 616, 618, 620, 624, 630, 636, 640, 642, 644, 648, 650, 654, 660, 666, 672, 678, 680, 684, 690, 696, 700, 702, 704, 708, 714, 720, 726, 728, 732, 736, 738, 740, 744, 748, 750, 756, 760, 762, 768, 770, 774, 780, 784, 786, 792, 798, 800, 804, 810, 812, 816, 820, 822, 828, 832, 834, 836, 840, 846, 852, 858, 860, 864, 868, 870, 876, 880, 882, 888, 894, 896, 900, 906, 910, 912, 918, 920, 924, 928, 930, 936, 940, 942, 945, 948, 952, 954, 960, 966, 968, 972, 978, 980, 984, 990, 992, 996, 1000, 1002, 1008, 1014, 1020, 1026, 1032, 1036, 1038, 1040, 1044, 1050, 1056, 1060, 1062, 1064, 1068, 1074, 1080, 1086, 1088, 1092, 1098, 1100, 1104, 1110, 1116, 1120, 1122, 1128, 1134, 1140, 1144, 1146, 1148, 1152, 1158, 1160, 1164, 1170, 1176, 1180, 1182, 1184, 1188, 1190, 1194, 1200, 1204, 1206, 1212, 1216, 1218, 1220, 1224, 1230, 1232, 1236, 1240, 1242, 1248, 1254, 1260, 1266, 1272, 1278, 1280, 1284, 1288, 1290, 1296, 1300, 1302, 1308, 1312, 1314, 1316, 1320, 1326, 1330, 1332, 1338, 1340, 1344, 1350, 1352, 1356, 1360, 1362, 1368, 1372, 1374, 1376, 1380, 1386, 1392, 1398, 1400, 1404, 1408, 1410, 1416, 1420, 1422, 1428, 1430, 1434, 1440, 1446, 1452, 1456, 1458, 1460, 1464, 1470, 1472, 1476, 1480, 1482, 1484, 1488, 1494, 1496, 1500, 1504, 1506

Ich habe aber die Vermutung, es ginge noch schneller? Vorschläge?

Zudem: Obiger Beitrag sollte nicht unfreundlich sein, aber jetzt en Idee, bei der ich noch etwas lerne. :D
 

cs1305

Mitglied
Tausend Dank ! Kann es einigermaßen nachvollziehen .. wäre leider nie selbst drauf gekommen.

Bei der unteren Lösung prüfst du alle von i/2 abwärts oder ? Und sobald der Rest 0 ist wird es zur Summe dazuaddiert. Ich hätte jetzt irgendwie gedacht man muss einen boolean dazu programmieren..Oder ist der Wert der if Schleife durch das == quasi ein boolean ? Sorry das ich so dumme fragen stelle
 
X

Xyz1

Gast
Oder ist der Wert der if Schleife durch das == quasi ein boolean
Ja, nicht nur quasi.

Dumme Fragen sind das nicht. Ich bin auch sicher, du lernst etwas dabei. Aber je nachdem wie viel Zeit dir für die Klausur bleibt ist eines der guten Bücher angebracht.

Ich spinne mal ein bisschen rum: Wenn es hundert solche möglichen Aufgaben gibt (habe ich das richtig geschrieben?) und 30 davon drankommen werden, dann hast du jetzt 1/30...

Und zu überheblich klingen will ich auch nicht. Ich denke, bei Wirtschaft bist du mir um einiges Vorraus. :oops:
 

tommysenf

Top Contributor
Ich habe aber die Vermutung, es ginge noch schneller? Vorschläge?
Natürlich:
Java:
private static final HashSet<Integer> ABS = new HashSet<>(Arrays.asList(new Integer[] {12, 18, 20, 24, 30, 36, 40, 42, 48, 54, 56, 60, 66, 70, 72, 78, 80, 84, 88, 90, 96, 100}));
 
  public static void main(String[] args)
  {
  
        for (int j = 0; j <=100; j++) {
            if (ABS.contains(j)) {
                System.out.print(j + ", ");
            }
        }
  }
 
  }
 

cs1305

Mitglied
Ich muss jetzt mal ganz dumm fragen... ich hab bisher nur mit public void und public int/double etc programmiert. Geht das dann genauso ? Irgendwie kriege ich das nicht hin... Muss ich nicht die Teiler in einer anderen Schleife irgendwie erstellen?
 

DrZoidberg

Top Contributor
Es kann doch nicht angehen, dass meine Lösung die beste Lösung ist? :oops:
Ein wenig kann man es noch verbessern, wenn man nur bis zur Wurzel der Zahl geht.
Java:
static boolean abu(int i) {
  int sum = 1;
  for(int j = 2; j*j <= i; j++) {
    if(i % j == 0) {
        sum += j;
        if(j*j < i) sum += i / j;
        if (sum > i) {
            return true;
        }
    }
  }
  return false;
}
 

cs1305

Mitglied
geht es auch so :
Java:
public static void main(String[] args) {
  int intervall =1000;
  int z = 0;
  int sum = 0;
  int sum2 =0;
  for(int c1=2; c1<=intervall; c1++) {      
    for(int c2=1; c2<c1; c2++) {
      z = c1 % c2;
      if (z==0){
        sum2=sum + c2;
        sum= sum2;
      }
    }
    if (c1==sum2){
      System.out.println(c1+" ist eine volkommende zahl");
    }
    if(c1<sum2){
      System.out.println(c1+" ist eine abundante zahl");      
    }
    sum=0;
    sum2=0;              
  }
  System.out.print("ENDE");
  }
}
 
Zuletzt bearbeitet von einem Moderator:
X

Xyz1

Gast
Ein wenig kann man es noch verbessern, wenn man nur bis zur Wurzel der Zahl geht
Ich glaube, du hast es etwas verwässert...
Sicher, dass es funktioniert?
Ich kann die Korrektheit nicht unmittelbar nachvollziehen.
j*j < i wird vielleicht durch i % j == 0 gar nicht erreicht.

Ich meine, dass man bis zur Hälfte der Zahl gehen muss, erscheint klar.
Theoretisch kann eine Zahl auch schon, ohne alle Teiler gesummt zu haben, die Eigenschaft 'abudant' inne haben.

Hast du mal Zeiten gemessen, auch wenn es sich hierbei um Micro-Micro-Optimierungen handelt?

@cs1305 : AFAICCS funktioniert Deines korrekt.
( Fein, ich bin der einzige im Internet, der naben afaics auch afaiccs (...'can'...) schreibt. ) ;)
 

DrZoidberg

Top Contributor
Ich glaube, du hast es etwas verwässert...
Sicher, dass es funktioniert?
Ich kann die Korrektheit nicht unmittelbar nachvollziehen.
j*j < i wird vielleicht durch i % j == 0 gar nicht erreicht.
Natürlich funktioniert das. Kannst du mir eine positive Zahl nennen für die meine Methode fehlschlägt?

Hast du mal Zeiten gemessen, auch wenn es sich hierbei um Micro-Micro-Optimierungen handelt?

Ja, hab ich.
Java:
public class Test {
  static boolean abu(int i) {
    int sum = 1;
    for (int j = i / 2; j > 1; j--) {
        if (i % j == 0) {
            sum += j;
            if (sum > i) {
                return true;
            }
        }
    }
    return false;
  }

  static boolean abu2(int i) {
    int sum = 1;
    for(int j = 2; j*j <= i; j++) {
      if(i % j == 0) {
          sum += j;
          if(j*j < i) sum += i / j;
          if (sum > i) {
              return true;
          }
      }
    }
    return false;
  }

  public static void main(String[] args) {
    long start = System.nanoTime();
    int count = 0;
    for (int j = 0; j < 100000; j++) {
      if (abu2(j)) count++;
    }
    long end = System.nanoTime();
    double time = (end - start)/1e6;
    System.out.println(count);
    System.out.println(time + "ms");

    start = System.nanoTime();
    count = 0;
    for (int j = 0; j < 100000; j++) {
      if (abu(j)) count++;
    }
    end = System.nanoTime();
    time = (end - start)/1e6;
    System.out.println(count);
    System.out.println(time + "ms");
  }
}

Ergebnis:
Code:
24794
60.611974ms
24794
8042.034928ms

Je grösser die Zahl, desto grösser der Unterschied in der Laufzeit. Wenn man alle Zahlen von 0 bis 100.000 durchgeht, hat man schon einen Faktor von mehr als 100.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
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
T Perfekte Zahlen ausgeben Java Basics - Anfänger-Themen 12
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
S Sequenz von Zahlen bei einem Stack möglich oder nicht möglich? Java Basics - Anfänger-Themen 5
N Methoden zur Rekursion (catalansche Zahlen) Java Basics - Anfänger-Themen 4
W Wie ziehe ich positive ungerade Zahlen von meinem Hauptwert ab? Java Basics - Anfänger-Themen 17

Ähnliche Java Themen

Neue Themen


Oben