es wird falsch gekürzt

Status
Nicht offen für weitere Antworten.

maeck

Mitglied
Hi,

ich bin noch recht neu in Java und bekomm ein Kürzungsproblem nicht auf die Reihe.
Habe folgenden Code:
Code:
public Rational(long numerator, long denominator) {
    	if (denominator == 0)
    			throw new ArithmeticException("Nenner darf nicht 0 sein!");
        long g = gcd(numerator, denominator);
        numerator /=g ;
        denominator /= g;
        this.zaehler = numerator;
        this.nenner = denominator;
    }
    
    private static long gcd(long a, long b) {
        while (b != 0) {
            long t = a % b;
            a = b;
            b = t;	
        	
        }
        return a;
    }
Wenn ich z.B. -100, 24 übergebe, dann sollten -25, 6 rauskommen. Es kommen aber 25,-6 raus.
Vielleicht häng ich auch schon zu lange dran, aber ich seh den Fehler leider nicht.
 

Leroy42

Top Contributor
Ich hab's jetzt nicht nachgeprüft, aber vielleicht liegt's ja an der
Verbindung des Modulo-Operators mit negativen Zahlen?

Rechne in deiner gcd-Methode doch mal mit den Absolutwerten. ???:L
 

maeck

Mitglied
Meines Wissens sollte Modulo mit negativen Zahlen klar kommen :(
Was meinst du mit Absolutwerten? Konkrete Zahlen?
 
S

SlaterB

Gast
schau dir doch deien gcd-Algorithmus an oder benutze lauter System.out.println um zu sehen, was dort passiert,

da wird a und b munter vertauscht, ohne dass auf das Vorzeichen geachtet wird,
am Ende kommt da zufällig 4 oder -4 raus,
spielt im Algorithmus keine Rolle,

du solltest also vor den endgültigen return das evtl. vorhande Negationszeichen entfernen:
return Math.abs(a);
oder so
 

maeck

Mitglied
Ja aber wenn ich das Vorzeichen entferne, dann funktioniert es auch nicht richtig.

Habe mir folgende Testdaten geschrieben:
Rational r = new Rational(100, 24);
assertEquals(25, r.numerator());
assertEquals(6, r.denominator());

r = new Rational(-100, -24);
assertEquals(25, r.numerator());
assertEquals(6, r.denominator());

r = new Rational(-100, 24);
assertEquals(-25, r.numerator());
assertEquals(6, r.denominator());

r = new Rational(100, -24);
assertEquals(-25, r.numerator());
assertEquals(6, r.denominator());

Wenn ich abs benutze, dann klappen die ersten beiden nicht, und wenn ich abs weg lasse, dann die letzten beiden nicht.

Also muss ich es noch anders lösen :(
 
S

SlaterB

Gast
na das sind ja merkwürdige Bedingungen,
so gehts für diese vier Fälle
(Regel: wenn zweite Zahl negativ, dann gcd negativ machen):

Code:
public class Rational {

    public Rational() {
        doSomething(100, 24);
        doSomething(-100, -24);
        doSomething(-100, 24);
        doSomething(100, -24);
    }

    public void doSomething(long numerator, long denominator) {
        if (denominator == 0)
            throw new ArithmeticException("Nenner darf nicht 0 sein!");
        long g = gcd(numerator, denominator);
        long numerator2 = numerator / g;
        long denominator2 = denominator / g;
        System.out.println("num: " + numerator + " den: " + denominator + " --> g: " + g + 
                " num2: " + numerator2 + " den2: " + denominator2);
    }

    private static long gcd(long a, long b) {
        boolean negative = ( b < 0 );
        while (b != 0) {
            long t = a % b;
            a = b;
            b = t;

        }
        a = Math.abs(a);
        if (negative) {
            return -a;
        } else {
            return a;
        }
    }

    public static void main(String[] args) {
        new Rational();
    }

}
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Was habe ich hier falsch, dass wenn ich z.B.: 11 eingebe mir false zurück gegeben wird? Java Basics - Anfänger-Themen 2
J String wird in GUI falsch ausgegeben Java Basics - Anfänger-Themen 10
B Wieso wird hier so viel als falsch angezeigt? Java Basics - Anfänger-Themen 2
S Variable wird falsch gesetzt Java Basics - Anfänger-Themen 5
J ArrayList wird in JTable falsch angezeigt Java Basics - Anfänger-Themen 0
D Aktuelles Datum wird falsch ausgegeben Java Basics - Anfänger-Themen 2
C Array wird falsch befüllt? Java Basics - Anfänger-Themen 7
F String wird richtig in konsole geschrieben aber falsch an Methode übergeben Java Basics - Anfänger-Themen 8
M .jar wird falsch generiert? Java Basics - Anfänger-Themen 9
R Ausgabe wird falsch angezeigt! Java Basics - Anfänger-Themen 14
1 Integer wird falsch in Datei geschrieben Java Basics - Anfänger-Themen 13
V Eingabe String wird falsch erkannt Java Basics - Anfänger-Themen 7
W Grid Layout wird falsch dargestellt Java Basics - Anfänger-Themen 4
P Schleife wird falsch durchlaufen!? Java Basics - Anfänger-Themen 3
S Komponent wird "falsch" platziert Java Basics - Anfänger-Themen 2
R Hashtable wird falsch ausgegeben Java Basics - Anfänger-Themen 5
K Warum wird mir auf der Konsole des Servers nicht "xxxx" angezeigt (Server/Client) Java Basics - Anfänger-Themen 4
K Warum wird hier nur etwas in eine txt Datei geschrieben und nicht in alle drei (InputStream/OutputStream/Reader/Writer) Java Basics - Anfänger-Themen 1
I Exception wird gefangen, aber trotzdem in Error Log? Java Basics - Anfänger-Themen 10
H JDK installieren jdk-21 wird nicht erkannt Java Basics - Anfänger-Themen 13
T if-else Bedingung wird ignoriert Java Basics - Anfänger-Themen 4
K Warum wird mir "Empfangen vom Client:" nicht sofort ausgegeben(Server/Client) Java Basics - Anfänger-Themen 3
P Webseite vom Smartmeter wird nur unleserlich angezeigt Java Basics - Anfänger-Themen 7
A Warum wird mein jdk nicht gefunden? Java Basics - Anfänger-Themen 3
J jar Befehl wird nicht erkannt Java Basics - Anfänger-Themen 7
M Anonyme Klassen - Warum wird in der Konsole nichts ausgegeben? Java Basics - Anfänger-Themen 1
T catch(InputMismatchException) wird nicht ausgefürt/erkannt Java Basics - Anfänger-Themen 12
berserkerdq2 Intelij, wie kann ich einstellen, dass die aktuelle Klasse ausgeführt wird, wenn ich aufs Startsymbol drücke, gibts da eine Tastenkombination? Java Basics - Anfänger-Themen 11
M Verständnisfrage: Warum wird die Datei ohne Inhalt übertragen Java Basics - Anfänger-Themen 3
Ostkreuz Wieso wird die Methode nochmal aufgerufen? Java Basics - Anfänger-Themen 5
Oneixee5 Maven Plugin wird 2 mal ausgeführt Java Basics - Anfänger-Themen 10
R Compiler-Fehler Variable wird nicht gefunden bzw. erkannt? Java Basics - Anfänger-Themen 2
D Interface Methode wird ungewollt in der Subklasse überschrieben Java Basics - Anfänger-Themen 5
C Was tun wenn .class erwartet wird ? Java Basics - Anfänger-Themen 6
T Meine Klasse wird nicht gefunden Java Basics - Anfänger-Themen 1
T Wie kann man es machen das ein Objekt nicht übermalt wird Java Basics - Anfänger-Themen 2
K Warum wird mir hier nach dem ersten Durchlauf zwei mal "welchen Datentyp wollen sie übergeben?" ausgegeben ? Java Basics - Anfänger-Themen 1
MiMa Ungültiges Datum wird nicht erkannt ?? Java Basics - Anfänger-Themen 6
schemil053 Multithread - Input verrutscht während etwas ausgegeben wird Java Basics - Anfänger-Themen 6
K REGEX - Rechnungsbetrag wird nicht richtig ausgelesen. Java Basics - Anfänger-Themen 3
_user_q Timer - ScheduledExecutorService wird schon vorher beendet Java Basics - Anfänger-Themen 5
X Erste Schritte Scanner eingabe wird übersprungen Java Basics - Anfänger-Themen 4
H Compiler-Fehler Klasse in einem Package wird nicht gefunden bzw. akzeptiert Java Basics - Anfänger-Themen 12
L Switch-Case Multiplikation wird nicht ausgegeben Java Basics - Anfänger-Themen 1
J In der Ausgabe wird ohne Eingabe in den else Block gesprungen. Java Basics - Anfänger-Themen 0
J In der Ausgabe wird ohne Eingabe in den else Block gesprungen. Java Basics - Anfänger-Themen 5
M Text wird in der Console nicht ausgegeben. Java Basics - Anfänger-Themen 11
I Methoden Wieso wird mein Array "a" verändert und meine Variable "a" nicht? Java Basics - Anfänger-Themen 4
S Datei anlegen Problem! Groß- und Kleinschreibung wird nicht unterschieden Java Basics - Anfänger-Themen 4
sserio Zweidimensionales Array [][] wird untereinander ausgegeben Java Basics - Anfänger-Themen 14
sserio Math. Befehl wird rot markiert Java Basics - Anfänger-Themen 5
M Rechteck wird nicht angezeigt Java Basics - Anfänger-Themen 3
B Bungeecord | ProxiedPlayer wird nicht in ArrayList hinzugefügt Java Basics - Anfänger-Themen 1
U Methode wird genutzt, ohne dass ich die aufrufe? Java Basics - Anfänger-Themen 4
S Methoden Return Rückgabewert wird nicht übergeben Java Basics - Anfänger-Themen 8
M Mein quellcode wird nicht in der Konsole ausgegeben Java Basics - Anfänger-Themen 3
I Code wird nicht ausgeführt Java Basics - Anfänger-Themen 2
M wird der Konstruktor nicht als 1. ausgeführt? Java Basics - Anfänger-Themen 13
G Main Methode wird beim ersten Aufruf nicht richtig ausgeführt Java Basics - Anfänger-Themen 1
K Präzedenregeln in Java sagen, dass +expr und -expr vor + von Addition und - von Addition stehen, warum wird dann z. B. a+b als eine Addition ausgeführ Java Basics - Anfänger-Themen 7
M Was wird hier genau getestet? Java Basics - Anfänger-Themen 9
M Wie schreibe ich eine if-Verzweigung um, so dass ein Bedingungsoperator benutzt wird? Java Basics - Anfänger-Themen 9
I Programm erkennt nicht an das Array zurückgegeben wird trotz Initialisierung *einfach* Java Basics - Anfänger-Themen 9
K Jlabel mit itemlistevent Text gegeben, wird nicht angezeigt Java Basics - Anfänger-Themen 5
P Mein Programm wird zwar erfolgreich Compiliert, öffnet sich aber nicht Java Basics - Anfänger-Themen 6
M Referenzen zuweisen und wird gleichzeitig ausgeführt Java Basics - Anfänger-Themen 6
O System.out.println wird nicht ausgegeben? Java Basics - Anfänger-Themen 11
Zrebna Umgebungsvariable Wieso wird meine verwendete JDK-Version in der Prompt nicht erkannt? Java Basics - Anfänger-Themen 6
el_pato DialogFenster wird nicht in Schleife geöffnet? Java Basics - Anfänger-Themen 30
J if-Schleife innerhalb einer if-Schleife wird in der Konsole nicht gelesen Java Basics - Anfänger-Themen 4
P Apache Derby wird in Eclipse trotz Anbindung nicht gefunden Java Basics - Anfänger-Themen 6
H Array wird als Rückgabewert nicht akzeptiert? Java Basics - Anfänger-Themen 2
Poppigescorn scan.nextInt() wiederholen bis eine Zahl eingeben wird Java Basics - Anfänger-Themen 7
F Session wird mehrfach erzeugt Java Basics - Anfänger-Themen 11
F Initialisieren eines Web-Mp3 Players in Tabs durch "booleans" erst wenn Tab geöffnet wird ...? Java Basics - Anfänger-Themen 1
fuerteb Compiler-Fehler Methode wird nicht bzw. als Fehler erkannt Java Basics - Anfänger-Themen 4
L JScrollPane wird nicht angezeigt Java Basics - Anfänger-Themen 10
D Hilfe beim Erzeugen eines Arrays NullPointerException wird ausgelöst Java Basics - Anfänger-Themen 11
J JTable Titel wird nicht angezeigt Java Basics - Anfänger-Themen 6
krgewb Long wird gerundet Java Basics - Anfänger-Themen 2
Zwanglos Warum wird nur die erste Zeile im while Block ausgeführt? Java Basics - Anfänger-Themen 8
F Wieso wird immer die falsche Mausposition angegeben? Java Basics - Anfänger-Themen 1
H GridPane wird nicht angezeigt Java Basics - Anfänger-Themen 0
M Java Spiel wie Wer wird Millionär Java Basics - Anfänger-Themen 1
H Endkapital wird nicht korrekt ausgegeben. Java Basics - Anfänger-Themen 5
C Methodenrückgabe wird in der main nicht berücksichtigt Java Basics - Anfänger-Themen 2
X compareTo Methode wird ignoriert Java Basics - Anfänger-Themen 7
kodela Hauptklasse wird nicht gefunden Java Basics - Anfänger-Themen 3
H Befehl wird nicht ausgeführt - System.out.println Java Basics - Anfänger-Themen 3
I Input/Output Code wird doppelt ausgeführt Java Basics - Anfänger-Themen 3
P Bedingung in Schleife wird nicht ausgeführt Java Basics - Anfänger-Themen 5
P Variablen HttpResponse.getBody() wird automatisch org.json Object und kann nicht zu json.simple Object gecastet werden? Java Basics - Anfänger-Themen 7
N Selection Algorithmus: Methode wird nicht erkannt (BlueJ) Java Basics - Anfänger-Themen 3
N package wird doppelt im exporer angezeigt Java Basics - Anfänger-Themen 2
N Bedinugng If-Abfrage wird nie erfüllt Java Basics - Anfänger-Themen 4
M Else wird nicht ausgeführt. Java Basics - Anfänger-Themen 5
H Wie wird ein String intern gespeichert? Java Basics - Anfänger-Themen 10
A char array wird überschrieben Java Basics - Anfänger-Themen 6
E Methoden Action Event wird nicht vollständig ausgeführt Java Basics - Anfänger-Themen 3
L Iterieren durch eine ArrayList. Integer Array wird übergeben Java Basics - Anfänger-Themen 17

Ähnliche Java Themen

Neue Themen


Oben