Eingabedaten berechnen

hhxum

Mitglied
Kann mir das jemand erklären, ich verstehe nicht genau wie man das machen soll..

vielen Dank im Voraus :)
 

Anhänge

  • B12F76EC-092C-480A-B4DC-BE22E43C0220.jpeg
    B12F76EC-092C-480A-B4DC-BE22E43C0220.jpeg
    74,1 KB · Aufrufe: 8

hhxum

Mitglied
Java:
Für Aufgabe d)
public class HybridSortRandomPivot extends HybridSort {
    // TODO: Implement
private Random random;
  
    public HybridSortRandomPivot() {    random = new Random();    }
  
    protected int selectPivot(int left, int right) {    return random.nextInt(right-left+1)+left;    }

                                                                                                        }

a)
public int compareTo(Card other) {
        // TODO: implement

        if (this.value < other.value) {    return -1;    }

        if (this.value > other.value) {    return 1;    }

        if (this.value == other.value) {
            if (suitValue(this.suit) < suitValue(other.suit)) {    return -1;    }
            if (suitValue(this.suit) > suitValue(other.suit)) {    return 1;    }    }

        return 0;    }
//Here numbers were assigned to the colors in ascending order.
    private int suitValue(Suit suit) {
        switch (suit) {
        case Diamonds:
            return 0;
        case Hearts:
            return 1;
        case Spades:
            return 2;
        case Clubs:
            return 3;

        default:    throw new RuntimeException();    }    }

                                                                                        }

b)
public void sort(SortArray array, int k) {
        assert(k>=0);
        // TODO: Implement
        this.k = k;
        this.array = array;
        quicksortRec(0, array.getNumberOfItems()-1);    }
  
  
    protected int selectPiv(int left, int right) {
        return left;    }
  
  
    private void quicksortRec(int left, int right) {
        if (left >= right) { return;    }
        if (right-left+1 < k) {    insertionSort(left,right);    }
            else {    int partitionIndex = partition(left, right);
                    quicksortRec(left, partitionIndex-1);
                    quicksortRec(partitionIndex+1, right);    }    }
  
  
    private int partition(int left, int right) {
        int pivotIndex = selectPiv(left, right);
        Card pivot = array.getElementAt(pivotIndex);
        swap(pivotIndex, left);
        int lastSmall = left;
      
        for (int j=left; j<=right; j++) {
            if (array.getElementAt(j).compareTo(pivot) < 0) {
                lastSmall = lastSmall+1;
                swap(lastSmall, j);    }    }
      
        swap(lastSmall, left);
        return lastSmall;    }
  
  
    private void insertionSort(int left, int right) {
        for (int j=left+1; j<=right; j++) {
            Card key = array.getElementAt(j);
            int i = j-1;
            while (i>=left && array.getElementAt(i).compareTo(key) > 0) {
                array.setElementAt(i+1, array.getElementAt(i));
                i=i-1;    }
            array.setElementAt(i+1, key);    }    }
  
    private void swap(int a, int b) {
        if (a==b) {
            return;    }
        Card temp = array.getElementAt(a);
        array.setElementAt(a, array.getElementAt(b));
        array.setElementAt(b, temp);    }
  
                                                                                    }
c) die Vorlage
public class HybridOptimizer {

    /**
     * Find the optimal value k of the HybridSort algorithm for
     * the given data. Note that we assume that the first local minimum is
     * the global minimum.
     * @param testData Data on which the optimal k should be calculated
     * [USER=49078]@Return[/USER] the optimal k
     */
    public static int optimize(ArrayList<Card> testData) {
        // TODO: implement
        return -1;
    }

}
 
Zuletzt bearbeitet:

MoxxiManagarm

Top Contributor
Ich hätte noch 2 Vorschläge zum bestehenden Code:
1) Sieht für mich so aus als wenn Suit ein Enum ist, stimmt das? Dann kannst du dir vermutlich den Switch-Case sparen und stattdessen die Ordinale für den Vergleich verwenden https://docs.oracle.com/en/java/javase/11/docs/api/java.base/java/lang/Enum.html#ordinal()
2) Du hast den Vergleich detailliert aufgeschrieben. Persönlich mache ich das nur noch selten, das kann schnell unübersichtlich und fehleranfällig werden. Du kannst dir vorgefertigte Comparatoren dafür zur Hilfe nehmen.

Diese Vorschläge sehen dann zusammen beispielhaft so aus:
Java:
public class Card implements Comparable<Card> {
    public enum Suit {
        Diamonds,
        Hearts,
        Spades,
        Clubs;
    }

    private Suit suit;
    private int value;

    public Card(Suit suit, int value) {
        this.suit = suit;
        this.value = value;
    }

    @Override
    public int compareTo(Card other) {
        return Comparator
                .comparingInt((Card c) -> c.value)
                .thenComparingInt((Card c) -> c.suit.ordinal())
                .compare(this, other);
    }


    @Override
    public String toString() {
        return "Card{" + "suit=" + suit.name() + ", value=" + value + '}';
    }

    public static void main(String... args) {
        List<Card> cards = new ArrayList<>();

        cards.add(new Card(Suit.Diamonds, 2));
        cards.add(new Card(Suit.Hearts, 13));
        cards.add(new Card(Suit.Hearts, 2));
        cards.add(new Card(Suit.Diamonds, 8));
        cards.add(new Card(Suit.Diamonds, 3));
        cards.add(new Card(Suit.Spades, 4));
        cards.add(new Card(Suit.Diamonds, 5));
        cards.add(new Card(Suit.Clubs, 9));
        cards.add(new Card(Suit.Diamonds, 5));
        cards.add(new Card(Suit.Spades, 11));
        cards.add(new Card(Suit.Diamonds, 10));
        cards.add(new Card(Suit.Hearts, 1));
        cards.add(new Card(Suit.Hearts, 2));
        cards.add(new Card(Suit.Spades, 7));

        cards.sort(Comparator.naturalOrder());

        cards.forEach(System.out::println);
    }
}

Ausgabe:
Code:
Card{suit=Hearts, value=1}
Card{suit=Diamonds, value=2}
Card{suit=Hearts, value=2}
Card{suit=Hearts, value=2}
Card{suit=Diamonds, value=3}
Card{suit=Spades, value=4}
Card{suit=Diamonds, value=5}
Card{suit=Diamonds, value=5}
Card{suit=Spades, value=7}
Card{suit=Diamonds, value=8}
Card{suit=Clubs, value=9}
Card{suit=Diamonds, value=10}
Card{suit=Spades, value=11}
Card{suit=Hearts, value=13}

Ansonsten zu deiner Aufgabe c). Das wichtigste ist, dass du für dich herausfindest was "Lokales Minimum" bedeudet. Wenn du das weißt st es eigentlich einfach.
 
Zuletzt bearbeitet:

hhxum

Mitglied
Ich hätte noch 2 Vorschläge zum bestehenden Code:
1) Sieht für mich so aus als wenn Suit ein Enum ist, stimmt das? Dann kannst du dir vermutlich den Switch-Case sparen und stattdessen die Ordinale für den Vergleich verwenden https://docs.oracle.com/en/java/javase/11/docs/api/java.base/java/lang/Enum.html#ordinal()
2) Du hast den Vergleich detailliert aufgeschrieben. Persönlich mache ich das nur noch selten, das kann schnell unübersichtlich und fehleranfällig werden. Du kannst dir vorgefertigte Comparatoren dafür zur Hilfe nehmen.

Diese Vorschläge sehen dann zusammen beispielhaft so aus:
Java:
public class Card implements Comparable<Card> {
    public enum Suit {
        Diamonds,
        Hearts,
        Spades,
        Clubs;
    }

    private Suit suit;
    private int value;

    public Card(Suit suit, int value) {
        this.suit = suit;
        this.value = value;
    }

    @Override
    public int compareTo(Card other) {
        return Comparator
                .comparingInt((Card c) -> c.value)
                .thenComparingInt((Card c) -> c.suit.ordinal())
                .compare(this, other);
    }


    @Override
    public String toString() {
        return "Card{" + "suit=" + suit.name() + ", value=" + value + '}';
    }

    public static void main(String... args) {
        List<Card> cards = new ArrayList<>();

        cards.add(new Card(Suit.Diamonds, 2));
        cards.add(new Card(Suit.Hearts, 13));
        cards.add(new Card(Suit.Hearts, 2));
        cards.add(new Card(Suit.Diamonds, 8));
        cards.add(new Card(Suit.Diamonds, 3));
        cards.add(new Card(Suit.Spades, 4));
        cards.add(new Card(Suit.Diamonds, 5));
        cards.add(new Card(Suit.Clubs, 9));
        cards.add(new Card(Suit.Diamonds, 5));
        cards.add(new Card(Suit.Spades, 11));
        cards.add(new Card(Suit.Diamonds, 10));
        cards.add(new Card(Suit.Hearts, 1));
        cards.add(new Card(Suit.Hearts, 2));
        cards.add(new Card(Suit.Spades, 7));

        cards.sort(Comparator.naturalOrder());

        cards.forEach(System.out::println);
    }
}

Ausgabe:
Code:
Card{suit=Hearts, value=1}
Card{suit=Diamonds, value=2}
Card{suit=Hearts, value=2}
Card{suit=Hearts, value=2}
Card{suit=Diamonds, value=3}
Card{suit=Spades, value=4}
Card{suit=Diamonds, value=5}
Card{suit=Diamonds, value=5}
Card{suit=Spades, value=7}
Card{suit=Diamonds, value=8}
Card{suit=Clubs, value=9}
Card{suit=Diamonds, value=10}
Card{suit=Spades, value=11}
Card{suit=Hearts, value=13}

Ansonsten zu deiner Aufgabe c). Das wichtigste ist, dass du für dich herausfindest was "Lokales Minimum" bedeudet. Wenn du das weißt st es eigentlich einfach.
Alles klar! Vielen Dank :)
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
M OOP Brüche nicht richtig berechnen Java Basics - Anfänger-Themen 3
V Durchschnittliche Volatility in Prozent für 4 Stunden berechnen Java Basics - Anfänger-Themen 14
T Fibonacci mit einer Hilfsmethode berechnen Java Basics - Anfänger-Themen 10
laxla123 Quersumme berechnen Java Basics - Anfänger-Themen 1
I For Schleife Summe berechnen Java Basics - Anfänger-Themen 13
S Vollmond berechnen und ausgeben Java Basics - Anfänger-Themen 12
S Vollkommene Zahl berechnen und ausgeben Java Basics - Anfänger-Themen 16
A Berechnen Moor Nachbarschaft Java Basics - Anfänger-Themen 5
E Geburtstag im Schaltjahr berechnen Java Basics - Anfänger-Themen 24
Lion.King Schaltjahr berechnen Java Basics - Anfänger-Themen 31
E Alter (Laufzeit) berechnen Java Basics - Anfänger-Themen 11
I Zuschläge berechnen Java Basics - Anfänger-Themen 15
L mit Fakultät mathematische Formel berechnen Java Basics - Anfänger-Themen 5
TanTanIsTrying Durschnitt berechnen von eingegebener Zahl bis 1 heruntergezählt Java Basics - Anfänger-Themen 9
L Präfix berechnen Java Basics - Anfänger-Themen 33
F Abstand zwischen zwei Objekten berechnen wie? Java Basics - Anfänger-Themen 1
Aemulit Java Schaltjahr berechnen Code Java Basics - Anfänger-Themen 7
Poppigescorn Quersumme Berechnen mit einer While Schleife Java Basics - Anfänger-Themen 13
I Potenz berechnen mit for-Schleife Java Basics - Anfänger-Themen 3
A Standardabweichung in Java berechnen Java Basics - Anfänger-Themen 10
H Gesamtabweichung mit Array berechnen Java Basics - Anfänger-Themen 2
G Java Rabatt berechnen Java Basics - Anfänger-Themen 8
V Rückgeld berechnen Java Basics - Anfänger-Themen 6
eleonori Durchschnitt aller Werte eines Baums berechnen Java Basics - Anfänger-Themen 5
Ianatrix Zahlen von a bis b berechnen Java Basics - Anfänger-Themen 7
L Max, min, Summe und Durchschnitt berechnen Java Basics - Anfänger-Themen 4
L Anhalteweg berechnen Java Basics - Anfänger-Themen 6
Aeon Erste Schritte Preise berechnen mit do-while Java Basics - Anfänger-Themen 9
M Quadratwurzel berechnen Java Basics - Anfänger-Themen 8
V Wachstum berechnen und in Ist-Formel verwenden Java Basics - Anfänger-Themen 5
N Variable aus anderen Variablen in statischer Klasse berechnen/abspeichern? Java Basics - Anfänger-Themen 4
M Abschreibungsplan berechnen Java Basics - Anfänger-Themen 23
V Gehalt berechnen in Java Java Basics - Anfänger-Themen 6
justemii Gehalt berechnen - Aufgabe Java-Programm Java Basics - Anfänger-Themen 9
L Anzahl der benachbarten Minen berechnen und setzen Java Basics - Anfänger-Themen 15
J Array Speicherplatz berechnen Java Basics - Anfänger-Themen 35
B Tranportkosten berechnen mit unterschiedlichen MwSt Java Basics - Anfänger-Themen 9
L Anzahl der Paare deren Summe = 0 ergibt berechnen Java Basics - Anfänger-Themen 0
V Erste Schritte Berechnen von Sinus; sin(x) ohne Math.* Java Basics - Anfänger-Themen 1
J Hilfe bei Java Aufgabe (Restschuld berechnen) Java Basics - Anfänger-Themen 11
N Ein Datum berechnen Java Basics - Anfänger-Themen 3
T Sparplan berechnen Java Basics - Anfänger-Themen 4
F Abstand zum Durchschnitt von 5 Zahlen berechnen... Java Basics - Anfänger-Themen 16
B java.util.Date berechnen Java Basics - Anfänger-Themen 11
P Mittelwert Arrayelemente berechnen Fehler Java Basics - Anfänger-Themen 5
CptK Best Practice Schussparabel berechnen Java Basics - Anfänger-Themen 3
T Modulo / Pow berechnen Java Basics - Anfänger-Themen 4
E Statistische Kennzahlen berechnen Java Basics - Anfänger-Themen 2
F Switch Case Modulo berechnen Java Basics - Anfänger-Themen 12
B mehrere Werte mit scanner und while schleife einlesen, max berechnen bzw addieren Java Basics - Anfänger-Themen 2
C Preis berechnen mit Java Java Basics - Anfänger-Themen 4
B Zahl in String abspeichern und später berechnen Java Basics - Anfänger-Themen 15
N Best Practice Image recognition fuzzy Superhash berechnen Java Basics - Anfänger-Themen 1
Dawinartor Erste Schritte Schaltjahr berechnen Java Basics - Anfänger-Themen 1
L Pi berechnen Java Basics - Anfänger-Themen 1
CptK Term (als String) berechnen und ausgeben Java Basics - Anfänger-Themen 10
L Den Winkel zwischen zwei Vektoren berechnen! Java Basics - Anfänger-Themen 2
J Variablen arithmetischen Mittelwert berechnen Java Basics - Anfänger-Themen 5
K Matrixen berechnen nach Worker Master Paradigma mit Threads Java Basics - Anfänger-Themen 4
R Winkel berechnen bzw. Geraden sortieren Java Basics - Anfänger-Themen 33
I Schnittpunkt zweier Geraden berechnen Java Basics - Anfänger-Themen 25
M Erste Schritte Mittelwert berechnen -> Methode in der Methode? Java Basics - Anfänger-Themen 14
S Compiler-Fehler Schaltjahr berechnen Java Basics - Anfänger-Themen 5
B Fakultätsfunktion Rekursiv Berechnen aber mit Array Java Basics - Anfänger-Themen 10
S Durchschnitt berechnen aus zwei Textfeldern Java Basics - Anfänger-Themen 21
D Summe berechnen mit verändertem Wert aus Schleife Java Basics - Anfänger-Themen 1
R Liga Berechnen Java Basics - Anfänger-Themen 1
P Klassen Berechnen mehrerer Map-Werte Java Basics - Anfänger-Themen 13
R Fussballtabellen berechnen Java Basics - Anfänger-Themen 12
J Fibonacci -Folge rekursiv berechnen Java Basics - Anfänger-Themen 18
J Durchschnitt jeder Zeile und und Spalte in einem 2D Arrays berechnen Java Basics - Anfänger-Themen 6
F ISBN Prüfziffer berechnen Java Basics - Anfänger-Themen 17
F Die Teilersumme einer Eingabe berechnen Java Basics - Anfänger-Themen 11
S Negafibonacci Folge berechnen Java Basics - Anfänger-Themen 24
G Array Mittelwert berechnen, wie? Java Basics - Anfänger-Themen 8
S Primzahlen berechnen funktioniert nicht richtig Java Basics - Anfänger-Themen 1
N Mit LocalDate alter berechnen Java Basics - Anfänger-Themen 3
J Laufzeit berechnen/Laufzeitanalyse Java Basics - Anfänger-Themen 2
N Arrays mit Zufallzahlen füllen und Statistiken berechnen Java Basics - Anfänger-Themen 5
A Wochentag berechnen Java Basics - Anfänger-Themen 10
Ste3et_C0st Vectoren berechnen Java Basics - Anfänger-Themen 8
L Durchschnitt in der Schleife berechnen Java Basics - Anfänger-Themen 11
A Kreisumfang/-Fläche vom Kreis berechnen Java Basics - Anfänger-Themen 39
L Wochentag berechnen Java Basics - Anfänger-Themen 5
L Rekursive Methode a * b berechnen Java Basics - Anfänger-Themen 2
B OOP Summe aus verschiedenen Instanzen einer Klasse berechnen Java Basics - Anfänger-Themen 2
N Dauer zwischen zwei LocalDateTime Objekten berechnen? Java Basics - Anfänger-Themen 4
P Ausdrücke berechnen Java Basics - Anfänger-Themen 2
V Mittelwert berechnen Java Basics - Anfänger-Themen 31
H Datentypen Tage zwischen zwei Datums berechnen Java Basics - Anfänger-Themen 4
P Quadrate berechnen Java Basics - Anfänger-Themen 3
S OOP Datumsunterschied in Tagen berechnen Java Basics - Anfänger-Themen 3
M Methoden Aus Timestamp das Datum berechnen Java Basics - Anfänger-Themen 3
B Schaltjahre berechnen! Java Basics - Anfänger-Themen 1
A werte in einem String berechnen Java Basics - Anfänger-Themen 3
F Checksummen aus int-Array berechnen Java Basics - Anfänger-Themen 3
F Toto-Tipp-Reihen berechnen Java Basics - Anfänger-Themen 1
N Threads Exception in thread "main"... Feher bei dem Versuch ein Radius zu berechnen Java Basics - Anfänger-Themen 4
R Quersumme berechnen - Methodenproblem Java Basics - Anfänger-Themen 1
S Button "Berechnen" geht nicht Java Basics - Anfänger-Themen 3

Ähnliche Java Themen

Neue Themen


Oben