Dumme Frage, aber...

Equated

Mitglied
Ich hab mir eine Aufgabe auf http://www.programmieraufgaben.ch angeschaut und versucht, zu lösen. Sie sieht wie folgt aus:

Schreiben Sie ein Programm, welches überprüft ob eine natürliche Zahl defiziente ist oder nicht.

Eine natürliche Zahl heißt defizient, wenn ihre echte Teilersumme (die Summe aller Teiler ohne die Zahl selbst) kleiner ist als die Zahl selbst. Ist die Teilersumme dagegen gleich der Zahl, spricht man von einer vollkommenen Zahl, ist sie groeßer, so spricht man von einer abundanten Zahl.

z.B : Eingabe: 80

Ausgabe: 80 ist keine defiziente Zahl [ 1 + 2 + 4 + 5 + 8 + 10 + 16 + 20 + 40 = 106 ].


An sich ist die Frage gar nicht schwierig, aber beim Programmieren kommt bei mir immer das Falsche raus. 80 soll keine defiziente Zahl sein, aber ich krieg immer das Gegenteil!?

Mein Code:

Java:
public class Runner {
   public static void main(String[] args) {
     Test t=new Test();
     System.out.println(t.Ueberpruefer(80));
   }
}

---------------------------------------------------------------------------------------------------
public class Test { 
   public String Ueberpruefer(int zahl)
   { for(int i=1; i<=zahl; i++)   
   { 
     int sum=0;
if(zahl%i==0)
      sum+=i;
    sum=sum-zahl;  
     
      if(sum>zahl)
      { return "Die Zahl ist nicht defizient!"; }
 
   }return "Die Zahl ist defizient";}
}

Bitte helft einem dummen Menschen bei der Fehlersuche. Ich steh auf dem Schlauch... :D
 
Zuletzt bearbeitet von einem Moderator:

Tarrew

Top Contributor
Also das liegt an 2 Sachen.

1. Wenn die Zahl durch i teilbar ist, dann rechnest du sum+=i, das ist richtig. Aber wofür ist das sum=sum-zahl ? Das solltest du löschen.

2. Du deklarierst die Variable sum in jedem Schleifendurchlauf neu. Deswegen wird nach jedem Schleifendurchlauf bei 0 angefangen. Du musst die Variable außerhalb der Schleife deklarieren.
 

Jardcore

Top Contributor
Durch die total verwurschtelte Formatierung kann man nicht erkennen ob und wo der Fehler ist, denn die Klammern sind schon totaler Mist :)

Code:
void main() {
  int zahl = 80;

  int sum = 0;
  for(int i = 0; i < zahl; i++) {
    if(zahl % i == 0) {
      sum += i;
    }
  }

  if(sum < zahl) {
    print('defizient');
  } else {
    print('nicht defizient');
  }
}

Hier mal ein Code aus Dart, so funktioniert es, und ich glaube dein Ansatz ist der gleiche.
 

CSHW89

Bekanntes Mitglied
Zwei Dinge zum Code von Jardcore. Erstens sollte man nicht bei 0 anfangen. Bin mir gerade nicht ganz sicher, aber modulo von 0 sollte ein Fehler schmeißen. Außerdem braucht man nicht bis 'zahl' prüfen, da man diesem Fall eh ausschließt. Also höchstens bis 'i < zahl' iterieren (wurde gerade schon korrigiert), oder noch besser 'i <= zahl/2', da 'zahl/2' der größte mögliche Teiler ist.

Man könnte es jetzt noch weiter optimieren, wenn man von 2 bis wurzel(zahl) iteriert und immer 'i' und 'zahl/i' hinzuaddiert, aber da muss man sehr auf die Grenzen aufpassen. Ich glaube, das würde hier jetzt zu weit führen.

lg Kevin
 
X

Xyz1

Gast
Mach es doch so:
Java:
    private static ArrayList<Integer> getTeiler(int value) {
        ArrayList<Integer> ali = new ArrayList<Integer>();
        for (int i = 1; i <= value / 2; i++) { // diese Schleife könnte schneller gemacht werden
            if (value % i == 0) {
                ali.add(i);
            }
        }
        return ali;
    }

    private static int getKat(int value, int sum) {
        if (sum < value) {
            return 1; // defizient
        } else if (value == sum) {
            return 2; // vollkommen
        } else {
            return 3; // abundant... es wird kleiner
        }
    }

switch (getKat(i, getSum(getTeiler(i)))) { ......

Code:
0              [] : vollkommen
1              [] : defizient
2             [1] : defizient
3             [1] : defizient
4          [1, 2] : defizient
5             [1] : defizient
6       [1, 2, 3] : vollkommen
7             [1] : defizient
8       [1, 2, 4] : defizient
9          [1, 3] : defizient
10       [1, 2, 5] : defizient
11             [1] : defizient
12 [1, 2, 3, 4, 6] : abundant

eine Summenfunktion müsstest du selber schreiben, das finde ich ganz gut ;)
 

Equated

Mitglied
Danke für die Antworten. Meine Lösung sieht jetzt so aus:

Java:
public class Runner {
   public static void main(String[] args) {
  
   Test t=new Test();
   System.out.println(t.Ueberpruefer(80));
  
   }
}

-------------------------------------------------------------------
public class Test {
   public String Ueberpruefer(int zahl)
   {
     int sum=0;
  
     for(int i=1; i<zahl; i++)
    
     { if(zahl%i==0)
  
       {
        sum+=i;      
        if(sum<zahl)
        {
            return "Das ist eine defiziente Zahl";
        }      
       } 
     }
  return "Das ist keine defiziente Zahl";
   }
}

Ich hoffe das sieht von den Klammern her in Ordnung aus. :/
 
Zuletzt bearbeitet von einem Moderator:

Jardcore

Top Contributor
Benutzte bitte das nächste Mal bitte die [ code ][ /code ] Tags!
Guck Mal wie schön das aussehen kann :)
Java:
public class Runner {

    public static void main(String[] args) {

        Test t = new Test();
        System.out.println(t.Ueberpruefer(80));
    }
}
Java:
public class Test {
    public String Ueberpruefer(int zahl) {
        int sum = 0;

        for(int i = 1 ; i < zahl; i++) {
            if(zahl % i == 0) {
                sum += i;
     
                if(sum < zahl) {
                    return "Das ist eine defiziente Zahl";
                }
            }
        }

        return "Das ist keine defiziente Zahl";
    }
}

Ich würde aber trotzdem empfehlen die Schleife nur bis zahl / 2 zu zählen und deine Abfrage if(sum < zahl) { } hinter die Schleife zu legen. Unt zusätzlich die Methode Ueberpruefe() klein zu schreiben und den Rückgabewert in boolean zu ändern.

Sonst vermischt du Logik mit GUI Kram.
also
Java:
if(t.ueberpruefe(80) {
    System.out.println("Das ist eine defiziente Zahl");
} else {
    System.out.println("Das ist keine defiziente Zahl");
}
 
Zuletzt bearbeitet:
K

kneitzel

Gast
Das if (sum < zahl) ist ja in der Schleife und das ist doch Unsinnig. So brichst Du die Schleife ab, sobald das erste mal sum erhöht wurde und sum<zahl ist.

Und wieso testest Du deinen Code nicht selbst? Du kannst die Funktion in einer main Funktion doch mit verschiedenen Argumenten aufrufen und das Ergebnis dann überprüfen!
 

Equated

Mitglied
So jetzt stimmt alles! Ich komm mir so blöd vor :/ aber Hauptsache ich habs endlich verstanden!
Danke für eure Unterstützung :p

Das ist raus gekommen: (auch getestet)

Java:
public class Runner {
   public static void main(String[] args) {
     // TODO Auto-generated method stub 
   
   Test t=new Test();
   t.Ueberpruefer(80);
   }
}

Java:
public class Test {
   public boolean Ueberpruefer(int zahl)
   {
     int sum=0;
   
     for(int i=1; i<zahl; i++)
     
     { if(zahl%i==0)
       {
        sum+=i;
       }
     }
         if(sum<zahl)
           {
            System.out.println("Das ist eine defiziente Zahl");
             return true;
           }
     else
       System.out.println("Das ist keine defiziente Zahl");
       return false;
   }
}
 
Zuletzt bearbeitet von einem Moderator:

Joose

Top Contributor
Kleine Anmerkung zu deinem Code: Achte auf eine korrekte Einrückung (eine IDE hilft dir dabei), dadurch wird der Code lesbarer und gewisse Fehler lassen sich anhand der Einrückung schon erkennen.

Beispiel:
Java:
     else
       System.out.println("Das ist keine defiziente Zahl");
       return false;
   }
}
Laut Einrückung schaut es so aus als sollte "return false" teil des else-Block sein. Da aber dein else keine Klammern hat wird nur die direkt darauffolgende Anweisung Teil des else-Block.
Außerdem rate ich auch wenn nur eine Anweisung in einem if- oder else-Block steht immer Klammern zu verwenden (besser mal zu viel machen, als vergessen und der Code macht etwas unerwartetes weil Klammern vergessen wurden ;))

Java:
public class Test {
   public boolean Ueberpruefer(int zahl) {
     int sum = 0;
     for(int i=1; i<zahl; i++) {
       if(zahl % i == 0) {
         sum += i;
       }
     }
     if(sum < zahl) {
       System.out.println("Das ist eine defiziente Zahl");
       return true;
     } else {
       System.out.println("Das ist keine defiziente Zahl");
     }
     return false;
   }
}
 
X

Xyz1

Gast
Ich will mich nicht zu weit aus dem Fenster lehnen, den dafür haben wir ja echte Mathem., aber wie wäre es, erst eine Primfaktorzerlegung durchzuführen und dann alle Teiler zu bestimmen. ;)
Dann ist die Schleife schon schneller.
Dann auch noch mal hier schauen:
http://www.homeconstructor.de/programm-in-java-alle-teiler-einer-zahl.html
alle teiler einer zahl ausgeben
20.04.2005
Perfekte Zahlen errechnen
24. Okt. 2010
Teiler einer Zahl ermitteln
9. Nov. 2009
Alle Teiler einer Zahl performant berechnen?
28. Mai 2007
Teiler einer ganzen Zahl
2. Nov. 2006
 
Zuletzt bearbeitet von einem Moderator:
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Dumme Frage: Wie interpretieren Java Basics - Anfänger-Themen 2
S Dumme Frage... String in Float umwandeln Java Basics - Anfänger-Themen 10
D dumme Frage! (was heist 'import java.util.*;' ?) Java Basics - Anfänger-Themen 3
D Eine GANZ dumme Frage Java Basics - Anfänger-Themen 22
S java für besonders dumme dummies oder ich bekomms nicht mal installiert Java Basics - Anfänger-Themen 29
P Ganz dumme Fragen Java Basics - Anfänger-Themen 7
Zrebna Frage zu Test-Driven Development (TDD) Java Basics - Anfänger-Themen 3
I Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen? Java Basics - Anfänger-Themen 15
I Frage Thymeleaf -> Prefix / Suffix ändern? Java Basics - Anfänger-Themen 11
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
T Frage zu Parse Java Basics - Anfänger-Themen 2
H Frage an die Profis Java Basics - Anfänger-Themen 4
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
H Frage zur Ausgabe Java Basics - Anfänger-Themen 4
H Frage zu arithmetischen Operationen Java Basics - Anfänger-Themen 20
F Kurze Frage zu replace() Java Basics - Anfänger-Themen 19
JavaSchmecktLecker Polymorphie Frage zur Methodenüberschreibung Java Basics - Anfänger-Themen 21
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
B Erste Schritte Frage zu Instanzierung und Referenzen Java Basics - Anfänger-Themen 8
DoubleM Runtime.getRuntime().exec Frage Java Basics - Anfänger-Themen 2
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
O Frage: Formaler Typbezeichner? Java Basics - Anfänger-Themen 3
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
N Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
N Spezielle frage zum Comparator Java Basics - Anfänger-Themen 6
L Frage zum Array Java Basics - Anfänger-Themen 1
A Frage zum UML Design Java Basics - Anfänger-Themen 1
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
izoards Drucken Frage zu FAQ Beitrag Java Basics - Anfänger-Themen 2
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
sserio Split() -> Regex Frage. Java Basics - Anfänger-Themen 7
A OCA Study Guide: 2. Frage aus Kapitel 3 Java Basics - Anfänger-Themen 9
sserio Date Library Frage Java Basics - Anfänger-Themen 9
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
sserio Frage zu HashMaps Java Basics - Anfänger-Themen 20
sserio Frage zu Threading - Multithreading Java Basics - Anfänger-Themen 2
sserio Frage zu Lambda Ausdrücken Java Basics - Anfänger-Themen 7
sserio Frage zu BigInteger Java Basics - Anfänger-Themen 1
D Frage bzgl. Enum-Handhabung Java Basics - Anfänger-Themen 16
xxx12 Frage Java Basics - Anfänger-Themen 2
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
A Frage zur programmierung Java Basics - Anfänger-Themen 12
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
R Input/Output Frage zu Java IO Java Basics - Anfänger-Themen 6
M Frage zu printWriter Java Basics - Anfänger-Themen 5
C Frage zu OLSMultipleLinearRegression Java Basics - Anfänger-Themen 31
KogoroMori21 Frage zum Euklidischen Algorithmus Java Basics - Anfänger-Themen 11
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
L Frage zur Ticket Maschine Java Basics - Anfänger-Themen 1
J Frage zu OOP-Klassendiagramm Java Basics - Anfänger-Themen 8
OSchriever Frage zu Compiler Java Basics - Anfänger-Themen 8
H Frage zu Throw Exception Java Basics - Anfänger-Themen 2
TimoN11 Frage zu Java-Vererbung (Cast) Java Basics - Anfänger-Themen 5
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
F Frage betreff Programmierbücher zu Lagerverwaltung als Konsolenprogramm Java Basics - Anfänger-Themen 3
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
I String.split regex Frage Java Basics - Anfänger-Themen 2
N Best Practice Frage zum MVC-Pattern Java Basics - Anfänger-Themen 2
dieter000 Frage zu einem Beispiel... Java Basics - Anfänger-Themen 5
J Frage zum Loggen Java Basics - Anfänger-Themen 18
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
Zrebna Frage zum "Referenzen-konzept" in Java Java Basics - Anfänger-Themen 8
JD_1998 Array-Position aus einer Methode in einer anderen ausgeben (Kurze Frage) Java Basics - Anfänger-Themen 2
marcooooo Frage zu bestimmten Beispiel Java Basics - Anfänger-Themen 31
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
N Input/Output Eine Frage über system.out.println. Java Basics - Anfänger-Themen 10
B Erste Schritte Learning Coding (!) Frage an erfahrene Programmierer. Java Basics - Anfänger-Themen 23
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
C Exception-Frage Java Basics - Anfänger-Themen 3
J Eine Frage zur Schreibweise == ? : Java Basics - Anfänger-Themen 3
S Frage des Designs Java Basics - Anfänger-Themen 1
JavaTalksToMe Extends/Implements Frage Java Basics - Anfänger-Themen 3
pkm Frage zu Servletfunktion Java Basics - Anfänger-Themen 0
B Frage zur Währungsumrechnung Java Basics - Anfänger-Themen 3
S Allgemeine Frage über Generics und Vererbungen Java Basics - Anfänger-Themen 5
Kirby.exe Frage zur Verwendung von Interfaces Java Basics - Anfänger-Themen 6
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
D Frage zur IDE IntelliJ IDEA Java Basics - Anfänger-Themen 6
H Frage zum 2d Array Java Basics - Anfänger-Themen 1
N Frage zum Newton-Fraktal Java Basics - Anfänger-Themen 1
H Frage zu interfaces Java Basics - Anfänger-Themen 1
J Frage dazu Variablen klassenübergreifend zu verändern Java Basics - Anfänger-Themen 22
I Frage zu SkipList Java Basics - Anfänger-Themen 4
G Frage zu JScrollPane Java Basics - Anfänger-Themen 12
Kirby.exe Allgemeine Frage Java Basics - Anfänger-Themen 3
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
J Kleine Frage zu OOP Java Basics - Anfänger-Themen 371
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
F Frage zu Iteratoren Java Basics - Anfänger-Themen 2
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
J Frage zur Vererbung Java Basics - Anfänger-Themen 1
H Frage zur ermittlung eines doppelte Paars aus Sotieralgorithmus Java Basics - Anfänger-Themen 4
H Frage zum Array Java Basics - Anfänger-Themen 17
G Schach -Frage 2- Maussteuerung Java Basics - Anfänger-Themen 7
G Schach in Java - Allgemeine Frage zur Architektur Java Basics - Anfänger-Themen 7

Ähnliche Java Themen

Neue Themen


Oben