Aufgaben¶
Hier finden Sie die Aufgaben. Die Abgabefristen der einzelnen Aufgaben stehen hier. Beachten Sie die nachfolgenden Hinweise zum Hochladen der Aufgaben.
Hinweise zur Abgabe der Aufgaben¶
Die Aufgaben laden Sie in Moodle unter dem Reiter "Aufgaben" hoch. Dort ist für jede Aufgabe eine Moodle-Aufgabe erstellt. Beachten Sie, dass ein Hochladen nach Ablauf der Abgabefrist nicht mehr möglich ist.
Eclipse¶
Sie sind in der Wahl Ihrer Entwicklungsumgebung frei. Ich verwende in der Veranstaltung Eclipse. Dafür gelten die folgenden Hinweise:
- Achten Sie darauf, dass Sie die Quelldateien (also die
.java-Dateien aus demsrc-Verzeichnis) hochladen. - Ihre Klassen erstellen Sie immer in einem package
aufgaben.aufgabeX. Das heißt, Aufgabe1 ist im packageaufgaben.aufgabe1, Aufgabe2 im packageaufgaben.aufgabe2usw. - In Ihrem
workspacegibt es dann einen Ordner für Ihr Java-Projekt, z.B.WS22(je nachdem, wie Sie Ihr Java-Projekt genannt haben) und darin befindet sich einbin- und einsrc-Ordner. In demsrc-Ordner befindet sich dann ein Ordneraufgabenund darin ein Ordneraufgaben1(für Aufgabe1). Darin befindet sich Ihre.java-Datei, die Sie hochladen sollen. Angenommen, Sie haben Ihre KlasseAufgabe1genannt, dann heißt die Klasse alsoAufgabe1.java. Sie folgen also dem Pfadworkspace→ Java-Projekt (z.B.WS22) →src→aufgaben→aufgabeX. - Wenn Ihre Lösung aus mehreren Klassen (mehreren
.java-Dateien) besteht, können Sie entweder die Dateien einzeln hochladen oder Sie zippen Ihre Dateien (am besten dann denaufgabeX-Ordner und laden das.zip-File hoch. - In Ihrer Lösung (Ihrer/n Klasse/n) fügen Sie direkt oberhalb Ihrer Klassendefinition einen JavaDoc-Kommentar ein (
/** ... */). Dieser enthält ein@author-Tag. dahinter schreiben Sie Ihren Namen. Das sieht dann z.B. so aus: - Sie können Ihre Aufgaben zu zweit lösen. Tragen Sie dann hinter das
@author-Tag beide Namen ein und laden Sie bitte beide die Lösung in Moodle hoch!
Aufgaben¶
Aufgabe 1 (Abgabe bis 22.11.2023 24:00 Uhr)¶
Aufgabe1 - Rhombus
- Erstellen Sie eine Klasse
Aufgabe1mitmain()-Methode im packageaufgaben.aufgabe1 - Implementieren Sie eine Methode
public static void printRhombus(int upperHalf, boolean filled){} - Ist der Parameterwert von
filledtrue, dann soll ein Rhombus (eine Raute) wie folgt auf die Konsole ausgegeben werden: - Ist der Parameterwert von
filledfalse, dann soll der Rhombus ungefüllt sein, also so: - der Wert für
upperHalfgibt die Höhe einer Hälfte des Rhombus an. Die Gesamthöhe des Rhombus berechnet sich aus ` - In unserem oben gezeigten Beispiel ist der Wert von
upperHalf5und die Gesamthöhe des Rhombus11. - Die obere Ausgabe ist also durch die Anweisung
printRhombus(5, true);und die untere durch die AnweisungprintRhombus(5, false);entstanden. - Die Berechnung der Höhe aus dem Parameterwert
upperHalfhat die Vorteile,- dass die Höhe dadurch immer eine ungerade Zahl ist (was notwendig ist) und
- dass Sie den Wert
upperHalfgut verwenden können (was ebenfalls notwendig ist, wie Sie merken werden)
- Tipp:: Schreiben Sie sich zwei weitere Methoden
public static void printRhombusFilled(int upperHalf){}undpublic static void printRhombusUnfilled(int upperHalf){}, die Sie entsprechend des Wertes vonfilledaufrufen. In der einen Methode erstellen Sie die ausgefüllte Raute und in der anderen die ungefüllte. Dann wird Ihr Programm nicht zu unübersichtlich. Fangen Sie am besten mit der ausgefüllten an, die ist etwas leichter. - Bedenken Sie auch, dass in jeder Zeile nicht nur eine bestimmte Anzahl Sterne ausgegeben werden muss, sondern erst noch eine bestimmte Anzahl Leerzeichen. Wieviele Leerzeichen sind es in Zeile
xbei einem gegebenen Wert fürupperHalf? Wieviele Sterne sind es in Zeilexbei einem gegebenen Wert fürupperHalf? Sie sollten diese Fragen zunächst mithilfe von Zettel und Stift beantworten ehe Sie mit dem Programmieren beginnen. Zettel und Stift sind die wichtigsten Hilfsmittel einer Programmiererin! - Das Programm soll für beliebige (nicht so große - max. Wert
100) positive Zahlen (also> 0) vonupperHalffunktionieren. Insbesondere sind die Tests fürupperhalf == 1interssant. - Laden Sie Ihre Lösung bis Dienstag, den 22.11.2022 um 24.00 Uhr in Moodle hoch
- Viel Spaß und viel Erfolg!
Aufgabe 2 (Abgabe bis 29.11.2023 24:00 Uhr)¶
Aufgabe2 - Numbers
- Erstellen Sie eine Klasse
Aufgabe2mitmain()-Methode im packageaufgaben.aufgabe2. - Bei der Lösung der Aufgabe soll nicht der Datentyp
Stringverwendet werden! -
Implementieren Sie eine Methode
public static int lengthOfNumber(int number){}. Diese Methode gibt die Länge vonnumberzurück, d.h. die Anzahl der Ziffern in der Zahl. Beachten Sie: fürnumber == 0soll jedoch0zurückgegeben werden.
Beispiele:
-
Implementieren Sie eine Methode
public static int firstDigit(int number){}. Diese Methode gibt die erste Ziffer vonnumberzurück.
Beispiele:
-
Implementieren Sie eine Methode
public static int powerOf10ToN(int n){}. Diese Methode gibt den Wert für10 ^ nzurück. Sie können davon ausgehen, dassn >= 0gilt.
Beispiele:
-
Implementieren Sie eine Methode
public static int cutFirstDigit(int number){}. Diese Methode entfernt vonnumberdie erste Ziffer. Für-10 < number < 10wird0zurückgegeben.
Beispiele:
-
Implementieren Sie eine Methode
public static boolean secondDigitIsZero(int number){}. Diese Methode gibt eintruezurück, wenn die zweite Ziffer innumbereine0ist. Sonstfalse.
Beispiele:
-
Testen Sie alle Methoden ausführlich in der
main()-Methode. -
Laden Sie Ihre Lösung bis Dienstag, den 29.11.2022 um 24.00 Uhr in Moodle hoch
- Viel Spaß und viel Erfolg!
Aufgabe 3 (Abgabe bis 06.12.2023 24:00 Uhr)¶
Aufgabe 3 - Triangle
-
Wir erstellen uns einen neuen Datentyp
Triangle -
Erstellen Sie im package
aufgaben.aufgabe3eine KlasseTriangleohnemain()-Methode und eine KlasseTestklassemitmain()-Methode. -
In der Klasse
Triangleerstellen Sie drei Objektvariablena,bundcjeweils vom Typintund alleprivate. Das sollen die Seiten unseres Dreiecks sein. -
Erstellen Sie einen Konstruktor, dem drei Parameterwerte übergeben werden
pa,pbundpcalle vom Typint. Mit diesen Werten werden die Objektvariablen initialisiert. -
Schreiben Sie eine Objektmethode
für den Fall, dass die Seitenlängenprint(), die die Seitenlängen des Dreiecks in der folgenden Form ausgibt:3,4und5sind. -
Wenn Sie jetzt in der
dann sollte die Ausgabe ungefähr so aussehen:main()-Methode derTestklassefolgende Anweisungen ausführen -
Erstellen Sie in der Klasse
Triangleeine Objektmethodepublic int circumference(), die den Umfang des Dreiecks zurückgibt (also die Summe der drei Seitenlängen). -
Erstellen Sie in der Klasse
Triangleeine Objektmethodepublic double area(), die den Flaecheninhalt des Dreiecks zurückgibt. Der FlächeninhaltAeines Dreiecks lässt sich nach der Heron'schen Formel wie folgt berechnen:- `A = Math.sqrt(s * (s-a) * (s-b) * (s-c)) (siehe Klasse Math)
- wobei
s = (a + b + c) / 2 - Achten Sie darauf, dass Sie stets mit
doublerechnen! - Beachten Sie, dass in einem Dreieck keine Seite länger sein darf als die Summe der beiden anderen. Für die oben in der
main()-Methode erstellten Objekte gilt das aber. Wir müssen deshalb nichts weiter beachten.
-
Erweitern Sie die Objektmethode
print()nun so, dass auch der Umfang und der Flaecheninhalt in der folgenden Form ausgegeben werden (Sie können in dieprint()-methode auch die Leerzeile integrieren):Seiten : a=3, b=4, c=5 Umfang : 12 Flaecheninhalt : 6.0 Seiten : a=4, b=4, c=7 Umfang : 15 Flaecheninhalt : 6.777720855862979 Seiten : a=5, b=5, c=5 Umfang : 15 Flaecheninhalt : 10.825317547305483 Seiten : a=4, b=5, c=3 Umfang : 12 Flaecheninhalt : 6.0 Seiten : a=4, b=3, c=5 Umfang : 12 Flaecheninhalt : 6.0 Seiten : a=3, b=4, c=5 Umfang : 12 Flaecheninhalt : 6.0 -
Erstellen Sie in der Klasse
Triangleeine Objektmethodepublic boolean equilateral(), die eintruezurückgibt, wenn das Dreieck gleichseitig ist (also alle Seiten des Dreiecks gleich lang sind) undfalsesonst. -
Erstellen Sie in der Klasse
Triangleeine Objektmethodepublic boolean isosceles(), die eintruezurückgibt, wenn das Dreieck gleichschenklig ist (also zwei Seiten des Dreiecks gleich lang sind) undfalsesonst. -
Erweitern Sie die Objektmethode
print()nun so, dass die Prüfungen, ob sich um ein gleichseitiges oder gleichschenkliges (oder unregelmäßiges) Dreieck handelt, in der folgenden Form ausgegeben werden:Seiten : a=3, b=4, c=5 Umfang : 12 Flaecheninhalt : 6.0 Das Dreieck ist unregelmaessig. Seiten : a=4, b=4, c=7 Umfang : 15 Flaecheninhalt : 6.777720855862979 Das Dreieck ist gleichschenklig. Seiten : a=5, b=5, c=5 Umfang : 15 Flaecheninhalt : 10.825317547305483 Das Dreieck ist gleichseitig. Seiten : a=4, b=5, c=3 Umfang : 12 Flaecheninhalt : 6.0 Das Dreieck ist unregelmaessig. Seiten : a=4, b=3, c=5 Umfang : 12 Flaecheninhalt : 6.0 Das Dreieck ist unregelmaessig. Seiten : a=3, b=4, c=5 Umfang : 12 Flaecheninhalt : 6.0 Das Dreieck ist unregelmaessig. -
Erstellen Sie in der Klasse
Triangleeine Objektmethodepublic boolean sameCircumference(Triangle t), die eintruezurückgibt, wenn das aufrufende Objekt den gleichen Umfang hat wietundfalsesonst. -
Erstellen Sie in der Klasse
Triangleeine Objektmethodepublic boolean isSmaller(Triangle t), die eintruezurückgibt, wenn das aufrufende Objekt einen kleineren Flächeninhalt hat, alstundfalsesonst. -
Erstellen Sie in der Klasse
Triangleeine Objektmethodepublic boolean isBigger(Triangle t), die eintruezurückgibt, wenn das aufrufende Objekt einen größeren Flächeninhalt hat, alstundfalsesonst. -
Testen Sie in der
main()-Methode derTestklassedie drei zuletztgeschriebenen Methoden, so dass folgende Ausgaben erzeugt werden:t1 und t2 gleicher Umfang ? : false t1 und t3 gleicher Umfang ? : false t2 und t3 gleicher Umfang ? : true t1 kleiner als t2 ? : true t2 kleiner als t1 ? : false t1 kleiner als t4 ? : false t4 kleiner als t1 ? : false t1 groesser als t2 ? : false t2 groesser als t1 ? : true t1 groesser als t4 ? : false t4 groesser als t1 ? : false
- Wenn Sie das geschafft haben, dann haben Sie die Aufgabe erfüllt! Herzlichen Glückwunsch! Die folgende(n) Aufgabe(n) sind optional :
-
Erstellen Sie in der Klasse
Triangleeine Objektmethodepublic boolean sidesAreEqual(Triangle t), die eintruezurückgibt, wenn das aufrufende Objekt die gleichen Seitenlängen hat wietundfalsesonst.- Beachten Sie, dass folgende Dreiecke mit z.B. dem Dreieck (
a=3, b=4, c=5) gleich sein sollen: (a=3, b=4, c=5), aber auch (a=4, b=5, c=3), aber auch (a=5, b=3, c=4) → die "Benennung" der Seiten ist also egal - Jedoch soll z.B. (
a=4, b=3, c=5) nicht gleich zu (a=3, b=4, c=5) sein - für die obigen Objekte soll somit gelten:
Erzeugen Sie diese Ausgabe in
t1 und t2 gleiche Seiten ? : false t1 und t4 gleiche Seiten ? : true t1 und t5 gleiche Seiten ? : false t1 und t6 gleiche Seiten ? : truemain().
- Beachten Sie, dass folgende Dreiecke mit z.B. dem Dreieck (
-
Erstellen Sie in der Klasse
Triangleeine Objektmethodepublic boolean isRightAngled(), die eintruezurückgibt, wenn das Dreieck rechtwinklig ist undfalsesonst.- der Satz des Pythagoras besagt, dass in einem rechtwinkligen Dreieck gilt:
a^2 + b^2 = c^2 - es gilt aber auch die Umkehrung, d.h. wenn von 2 Seiten die Summe der Quadrate dem Quadrat der dritten Seite entspricht, dann ist das Dreieck rechtwinklig
- der Satz des Pythagoras besagt, dass in einem rechtwinkligen Dreieck gilt:
-
Erweitern Sie die Objektmethode
print()nun so, dass die Prüfungen, ob sich um ein rechtwinkliges Dreieck handelt, in der folgenden Form ausgegeben werden:Seiten : a=3, b=4, c=5 Umfang : 12 Flaecheninhalt : 6.0 Das Dreieck ist unregelmaessig. Das Dreieck ist rechtwinklig. Seiten : a=4, b=4, c=7 Umfang : 15 Flaecheninhalt : 6.777720855862979 Das Dreieck ist gleichschenklig. Das Dreieck ist nicht rechtwinklig. Seiten : a=5, b=5, c=5 Umfang : 15 Flaecheninhalt : 10.825317547305483 Das Dreieck ist gleichseitig. Das Dreieck ist nicht rechtwinklig. Seiten : a=4, b=5, c=3 Umfang : 12 Flaecheninhalt : 6.0 Das Dreieck ist unregelmaessig. Das Dreieck ist rechtwinklig. Seiten : a=4, b=3, c=5 Umfang : 12 Flaecheninhalt : 6.0 Das Dreieck ist unregelmaessig. Das Dreieck ist rechtwinklig. Seiten : a=3, b=4, c=5 Umfang : 12 Flaecheninhalt : 6.0 Das Dreieck ist unregelmaessig. Das Dreieck ist rechtwinklig. -
Laden Sie Ihre Lösung bis Dienstag, den 06.12.2023 um 24.00 Uhr in Moodle hoch
- Viel Spaß und viel Erfolg!
Aufgabe 4 (Abgabe bis 13.12.2023 24:00 Uhr)¶
Aufgabe 4 - Bruch
-
Wir erstellen uns einen neuen Datentyp
Bruch -
Erstellen Sie im package
aufgaben.aufgabe4eine KlasseBruchohnemain()-Methode und eine KlasseBruchTestmitmain()-Methode. -
In der Klasse
Brucherstellen Sie zwei Objektvariablenzaehlerundnennerjeweils vom Typintundprivate. -
Implementieren Sie für die Klasse
Bruchzwei verschiedene Konstruktoren- parameterlos →
zaehlerundnennererhalten jeweils den Wert1 - mit zwei Parametern (
int zaehler, int nenner) → entspr. Werte der Objektvariablen
- parameterlos →
-
Implementieren Sie folgende Objektmethoden
public Bruch plus(Bruch b)→ gibt den gekürzten Bruch aus der Addition eines Bruchs mitbzurückpublic Bruch minus(Bruch b)→ gibt den gekürzten Bruch aus der Subtraktion eines Bruchs mitbzurückpublic Bruch mal(Bruch b)→ gibt den gekürzten Bruch aus der Multiplikation eines Bruchs mitbzurückpublic Bruch geteilt(Bruch b)→ gibt den gekürzten Bruch aus der Division eines Bruchs mitbzurückpublic Bruch kuerzen()→ gibt den gekürzten Bruch zurück (Sie brauchen dazu denggT) _public String toString()→ gibt einen Bruch alsStringin der Formzaehler / nennerzurückpublic int ggT(int zahl1, int zahl2)→ gibt den größten gemeinsamen Teiler (ggT) der beiden Zahlenzahl1undzahl2alsintzurück - siehe Euklidischer Algorithmus
-
Geben Sie in die
main()-Methode derBruchTest-Klasse mindestens folgende Anweisungen ein:und führen Sie dieBruch b1 = new Bruch(3,7); Bruch b2 = new Bruch(4,8); Bruch b3 = new Bruch(2,5); Bruch b4 = new Bruch(5,11); Bruch b5 = new Bruch(); System.out.printf("%n%n------------------------- Rechnen -----------------------------------%n%n"); System.out.printf("%5s + %5s = %5s %n", b1.toString(), b2.toString(), b1.plus(b2).toString()); System.out.printf("%5s - %5s = %5s %n", b3.toString(), b4.toString(), b3.minus(b4).toString()); System.out.printf("%5s * %5s = %5s %n", b1.toString(), b3.toString(), b1.mal(b3).toString()); System.out.printf("%5s / %5s = %5s %n", b2.toString(), b1.toString(), b2.geteilt(b1).toString()); System.out.printf("%5s + %5s = %5s %n", b5.toString(), b4.toString(), b5.plus(b4).toString()); System.out.printf("%5s - %5s = %5s %n", b1.toString(), b1.toString(), b1.minus(b1).toString()); // nenner sollte ungleich 0 bleiben!BruchTest-Klasse aus. Es sollten folgende Augaben entstehen:
- Wenn Sie das geschafft haben, dann haben Sie die Aufgabe erfüllt! Herzlichen Glückwunsch! Die folgende(n) Aufgabe(n) sind optional :
-
Implementieren Sie folgende Objektmethoden
public boolean istGroesser(Bruch b)→ gibttruezurück, wenn der aufrufende Bruch größer alsbist,falsesonstpublic boolean istKleiner(Bruch b)→ gibttruezurück, wenn der aufrufende Bruch kleiner alsbist,falsesonstpublic boolean istGleich(Bruch b)→ gibttruezurück, wenn der aufrufende Bruch gleichbist,falsesonst
-
Geben Sie in die
main()-Methode derBruchTest-Klasse mindestens folgende weitere Anweisungen ein:und führen Sie dieSystem.out.printf("%n%n------------------------- Vergleichen -----------------------------------%n%n"); System.out.printf("%5s > %5s ? %b %n", b1.toString(), b2.toString(), b1.istGroesser(b2)); System.out.printf("%5s < %5s ? %b %n", b1.toString(), b2.toString(), b1.istKleiner(b2)); System.out.printf("%5s == %5s ? %b %n", b1.toString(), b2.toString(), b1.istGleich(b2)); System.out.printf("%5s > %5s ? %b %n", b3.toString(), b4.toString(), b3.istGroesser(b4)); System.out.printf("%5s < %5s ? %b %n", b3.toString(), b4.toString(), b3.istKleiner(b4)); System.out.printf("%5s == %5s ? %b %n", b3.toString(), b4.toString(), b3.istGleich(b4)); System.out.printf("%5s > %5s ? %b %n", b5.toString(), b5.toString(), b5.istGroesser(b5)); System.out.printf("%5s < %5s ? %b %n", b5.toString(), b5.toString(), b5.istKleiner(b5)); System.out.printf("%5s == %5s ? %b %n", b5.toString(), b5.toString(), b5.istGleich(b5));BruchTest-Klasse aus. Es sollten folgende weitere Augaben entstehen: -
Laden Sie Ihre Lösung bis Dienstag, den 13.12.2022 um 24.00 Uhr in Moodle hoch
- Viel Spaß und viel Erfolg!
Aufgabe 5 (Abgabe bis 20.12.2023 24:00 Uhr)¶
Aufgabe 5 - Doppelt-verkettete Liste
-
Wir erstellen uns einen neuen Datentyp
ListElement. Dieser Datentyp wird für ein Element aus einer doppelt verketteten Liste verwendet. Eine Liste kann aus vielenListElement-Elementen bestehen. EinListElementhat einen Vorgänger (predecessor) und einen Nachfolger (successor) in der Liste. Nur das erste Element hat keinen Vorgänger und das letzte Element hat keinen Nachfolger. -
Erstellen Sie im package
aufgaben.aufgabe5eine KlasseListElementohnemain()-Methode und eine KlasseProgrammklassemitmain()-Methode. -
In der Klasse
ListElementerstellen Sie fünf nur in der Klasse sichtbare Objektvariablen:valuevom TypcharhasPredecessorvom TypbooleanhasSuccessorvom Typbooleanpredecessorvom TypListElementundsuccessorvom TypListElement
-
Implementieren Sie für die Klasse
ListElementeinen Konstruktor, dem ein Zeichen (char) als Parameter übergeben wird. Dieses Zeichen wird verwendet, um der Objektvariablenvalueeinen Wert zuzuweisen. Setzen Sie außerdem die ObjektvariablenhasPredecessorundhasSuccessorjeweils auffalse. -
Implementieren Sie die Objektmethode
public void insertBefore(ListElement element). Durch Aufruf dieser Methode soll das aufrufendeListElement-Objekt vor dasListElement-Objektelementin die Liste eingefügt werden. Dabei sind mehrere Dinge zu beachten:-
Angenommen, wir haben zwei einzelne
ListElement-Objektel1undl2. Dann entsteht durchli.insertBefore(l2)die Listel1 <--> l2. Das heißt,l2wird dersuccessorvonl1undl1wird derpredecessorvonl2. Setzen Sie entsprechend auch die Variablenwerte fürhasSuccessorundhasPredecessor. -
Angenommen, wir haben ein einzelnes
ListElement-Objektl1und eine Liste aus lauterListElement-Objektenl2 <--> l3 <--> l4 <--> l5. Dann- ensteht durch
l1.insertBefore(l2)die Listel1 <--> l2 <--> l3 <--> l4 <--> l5und alles ist, wie im Fall zuvor, d.h.l1ist derpredecessorvonl2undl2ist dersuccessorvonl1. - entsteht durch
l1.insertBefore(l3)die Listel2 <--> l1 <--> l3 <--> l4 <--> l5. Das bedeutet, dassl3dersuccessorvonl1wird undl1derpredecessorvonl3. Der altepredecessorvonl3(l2) wird der neuepredecessorvonl1undl1wird der neuesuccessorvonl2.
- ensteht durch
-
Angenommen, wir haben eine Liste aus lauter
ListElement-Objektenl1 <--> l2 <--> l3und ein einzelnesListElement-Objektl4. Dann- ensteht sowohl durch
l1.insertBefore(l4)als auch durchl2.insertBefore(l4)als auch durchl3.insertBefore(l4)die Listel1 <--> l2 <--> l3 <--> l4.
- ensteht sowohl durch
-
Angenommen, wir haben eine Liste aus lauter
ListElement-Objektenl1 <--> l2 <--> l3und eine Liste aus lauterListElement-Objektenl4 <--> l5 <--> l6 <--> l7. Dann- ensteht durch
l1.insertBefore(l4)die Listel1 <--> l2 <--> l3 <--> l4 <--> l5 <--> l6 <--> l7. Das heißt, es wird die gesamte Liste, die mitl1beginnt, vorl4eingefügt (und damit vor die Listel4 <--> l5 <--> l6 <--> l7). - entsteht durch
l1.insertBefore(l6)die Listel4 <--> l5 <--> l1 <--> l2 <--> l3 <--> l6 <--> l7. - übrigens: wenn Sie für die gebebenen Lsten z.B.
l2.insertBefore(l5)aufrufen, dann fälltl1weg, d.h. die entstehende Liste istl4 <--> l2 <--> l5 <--> l6 <--> l7. Sie können sich überlegen, ob das überhaupt ein richtiges Verhalten ist oder ob es ein besseres gibt.
- ensteht durch
-
-
Tipp: Beginnen Sie mit der Implementierung des ersten (und einfachsten) Falls. Fügen Sie dann die weiteren Fälle schrittweise hinzu. Sie werden feststellen, dass Sie gar nicht viele Fallunterscheidungen machen müssen. Ich bin z.B. mit einem
ifund einerwhile-Schleife ausgekommen und die gesamte Methode hat nur ca. 10 Zeilen. -
Implementieren Sie die Objektmethode
public void print(). Diese Methode soll denvaluedes aufrufendenListElement-Objektes auf die Konsole ausgeben (ohne Zeilenumbruch) und dann dieprint()-Methode dessuccessor-Elementes aufrufen. Nur wenn das aufrufendeListElementkeinensuccessorhat (Ende der Liste), wird der Wert des Objektes mit Zeilenumbruch ausgegeben und keine weitereprint()-Methode aufgerufen. -
Geben Sie in die
main()-Methode derProgrammklassemindestens folgende Anweisungen ein:und führen Sie dieListElement l1 = new ListElement('W'); ListElement l2 = new ListElement('e'); ListElement l3 = new ListElement('i'); ListElement l4 = new ListElement('h'); ListElement l5 = new ListElement('n'); ListElement l6 = new ListElement('a'); ListElement l7 = new ListElement('c'); ListElement l8 = new ListElement('h'); ListElement l9 = new ListElement('t'); ListElement l10 = new ListElement('e'); ListElement l11 = new ListElement('n'); System.out.printf("? : %15s", "W == ");l1.print(); l1.insertBefore(l2); // W-e System.out.printf("? : %15s", "We == ");l1.print(); l5.insertBefore(l6); // n-a l5.insertBefore(l7); // na-c l7.insertBefore(l8); // nac-h l6.insertBefore(l9); // nach-t System.out.printf("? : %15s", "nacht == ");l5.print(); l1.insertBefore(l5); // We-nacht System.out.printf("? : %15s", "Wenacht == ");l1.print(); l10.insertBefore(l11); // e-n l9.insertBefore(l10); // Wenacht-en System.out.printf("? : %15s", "Wenachten == ");l1.print(); System.out.printf("? : %15s", "nachten == ");l5.print(); l3.insertBefore(l5); // We-i-nachten System.out.printf("? : %15s", "inachten == ");l3.print(); System.out.printf("? : %15s", "Weinachten == ");l1.print(); l4.insertBefore(l5); // Wei-h-nachten System.out.printf("? : %15s", "Weihnachten == ");l1.print();Programmklasseaus. Es sollten folgende Augaben entstehen:
-
Wenn Sie das geschafft haben, dann haben Sie die Aufgabe erfüllt! Herzlichen Glückwunsch! Die folgende Aufgabe ist optional :
- Fügen Sie der Klasse
ListElementdie Objektvariableprivate int indexhinzu und sorgen Sie dafür, dass in einer verketteten Liste dieListElement-Objekte den jeweils passenden Index entsprechend ihrer Position in der Liste haben (beginnend bei0). Also in der Listel1 <--> l2 <--> l3 <--> l4 <--> l5hatl1den Index0,l2den Index1,l3den Index2usw. Wenn Sie dafür selbständig eine Lösung entwickelt haben, dann schicken Sie mir bitte eine E-Mail mit der Lösung.
- Fügen Sie der Klasse
- Laden Sie Ihre Lösung bis Dienstag, den 20.12.2022 um 24.00 Uhr in Moodle hoch
- Viel Spaß und viel Erfolg!
Aufgabe 6 (Abgabe bis 03.01.2024 24:00 Uhr)¶
Aufgabe 6 - Arrays ausgeben
-
Wir geben Arrays in verschiedenen Arten auf der Konsole aus.
-
Implementieren Sie eine Methode
public static int[] createAndFillArray(int length, int fromInclusive, int toInclusive). Diese Methode soll genau so sein, wie diecreateAndFillArray(int length, int bound)-Methode in Methoden mit Array als Rückgabe mit dem einzigen Unterschied, dass wir nicht denboundangeben (der sorgt ja dafür, dass wir Zufallswerte aus dem Bereich[0, 1, ... , bound-1]erzeugen), sondernfromInclusiveundtoExclusive, so dass wir Zufallswerte aus dem Wertebereich[fromInclusive, ... , toInclusive]erzeugen. Siehe dazu auchnextInt(bound). -
Implementieren Sie eine Methode
public static void printArray(int[] a)so, dass sie einint-Array in der Form[ 27, 30, 25, 26, 23, 20, 30, 30, 22, 21, 29, 29, 21, 20 ](also Werte durch Komma getrennt in eckigen Klammern) ausgibt. Siehe dazu Ausgabe von Arrays. -
Rufen Sie in der
main()die beiden Methoden wie folgt auf: -
Implementieren Sie eine Methode
public static void printTable(int[] a). Diese gibt das Arrayaals Tabelle in folgender Form aus: -
Rufen Sie in der
main()die MethodeprintTable()wie folgt auf: -
Implementieren Sie eine Methode
public static void printHorizontal(int[] a). Diese gibt das Arrayain folgender Form aus:Das heißt, für jeden Wert im Array wird die entsprechende Anzahl von Sternen ausgegeben. Ganz links steht jeweils der Index, unter dem der Wert im Array gespeichert wird.| 0 | *************************** | 1 | ****************************** | 2 | ************************* | 3 | ************************** | 4 | *********************** | 5 | ******************** | 6 | ****************************** | 7 | ****************************** | 8 | ********************** | 9 | ********************* | 10 | ***************************** | 11 | ***************************** | 12 | ********************* | 13 | ******************** | -
Rufen Sie in der
main()die MethodeprintTable()wie folgt auf:
- Wenn Sie das geschafft haben, dann haben Sie die Aufgabe erfüllt! Herzlichen Glückwunsch! Die folgende(n) Aufgabe(n) sind optional :
-
Implementieren Sie eine Methode
public static void printUpsideDown(int[] a)oder eine Methodepublic static void printVertical(int[] a)(beide gleicher Aufwand). Diese geben das Arrayain folgender Form aus:----------- printUpsideDown ------------ | 0 1 2 3 4 5 6 7 8 9 10 11 12 13 ----+---------------------------------------------------------------------- 1 | * * * * * * * * * * * * * * 2 | * * * * * * * * * * * * * * 3 | * * * * * * * * * * * * * * 4 | * * * * * * * * * * * * * * 5 | * * * * * * * * * * * * * * 6 | * * * * * * * * * * * * * * 7 | * * * * * * * * * * * * * * 8 | * * * * * * * * * * * * * * 9 | * * * * * * * * * * * * * * 10 | * * * * * * * * * * * * * * 11 | * * * * * * * * * * * * * * 12 | * * * * * * * * * * * * * * 13 | * * * * * * * * * * * * * * 14 | * * * * * * * * * * * * * * 15 | * * * * * * * * * * * * * * 16 | * * * * * * * * * * * * * * 17 | * * * * * * * * * * * * * * 18 | * * * * * * * * * * * * * * 19 | * * * * * * * * * * * * * * 20 | * * * * * * * * * * * * * * 21 | * * * * * * * * * * * * 22 | * * * * * * * * * * 23 | * * * * * * * * * 24 | * * * * * * * * 25 | * * * * * * * * 26 | * * * * * * * 27 | * * * * * * 28 | * * * * * 29 | * * * * * 30 | * * * ----------- printVertical -------------- 30 | * * * 29 | * * * * * 28 | * * * * * 27 | * * * * * * 26 | * * * * * * * 25 | * * * * * * * * 24 | * * * * * * * * 23 | * * * * * * * * * 22 | * * * * * * * * * * 21 | * * * * * * * * * * * * 20 | * * * * * * * * * * * * * * 19 | * * * * * * * * * * * * * * 18 | * * * * * * * * * * * * * * 17 | * * * * * * * * * * * * * * 16 | * * * * * * * * * * * * * * 15 | * * * * * * * * * * * * * * 14 | * * * * * * * * * * * * * * 13 | * * * * * * * * * * * * * * 12 | * * * * * * * * * * * * * * 11 | * * * * * * * * * * * * * * 10 | * * * * * * * * * * * * * * 9 | * * * * * * * * * * * * * * 8 | * * * * * * * * * * * * * * 7 | * * * * * * * * * * * * * * 6 | * * * * * * * * * * * * * * 5 | * * * * * * * * * * * * * * 4 | * * * * * * * * * * * * * * 3 | * * * * * * * * * * * * * * 2 | * * * * * * * * * * * * * * 1 | * * * * * * * * * * * * * * ----+---------------------------------------------------------------------- | 0 1 2 3 4 5 6 7 8 9 10 11 12 13 -
Rufen Sie in der
main()die beiden Methoden (oder die, die Sie implememntiert haben) wie folgt auf: -
Tipps zum Lösen der Zusatzaufgabe:
- Sie müssen zunächst ermitteln, welcher der größte Wert innerhalb des Arrays ist, denn dieser gibt Ihnen die Anzahl der Zeilen im Diagramm vor.
- Stellen Sie sich das Problem als eine Matrix aus Zeilen und Spalten vor. Die Spalten lassen sich auf den Index des Arrays mappen und die Zeilen auf die Werte im Array.
-
Laden Sie Ihre Lösung bis Dienstag, den 03.01.2023 um 24.00 Uhr in Moodle hoch
- Viel Spaß und viel Erfolg!
Aufgabe 7 (Abgabe bis 10.01.2024 24:00 Uhr)¶
Aufgabe 7 - Arrays befüllen
-
Wir befüllen ein
char-Array, aber das ist leider gar nicht so einfach ;-) -
einleitende Vorbetrachtung: angenommen, wir haben die folgende Schleife:
-
Durch diese wird uns das gesamte Alphabet in Kleinbuchstaben ausgegeben:
-
Kopieren Sie die Schleife einfach in Ihre
main()-Methode und führen Sie sie aus, dann erhalten Sie obige Ausgabe. Dahinter steckt, dass wir derint-VariablenasciiValueden ASCII-Code der Kleinbuchstaben zuweisen (beginnend bei97- das ist eina). Siehe z.B. hier. Der letzte kleine Buchstabezhat den ASCII-Wert122, deshalb läuft die Schleife auch bis<123. In Zeile3der Schleife findet eine Typkonvertierung statt. Aus demintwird einchar. Dies geschieht durch den Typkonvertierungsoperator(char). In Zeile4wird das Zeichencvom Typcharausgegeben. -
Aufgabe Die Aufgabe ist es nun, ein
char-Array zu befüllen. Es gelten folgende Bedingungen:- das Array hat (nur) die Länge
25 - in dem Array darf es keine Doppelungen geben (also kein Zeichen darf doppelt enthalten sein)
- die Zeichen werden zufällig erzeugt, d.h. mithilfe der Klasse
Randomund der MethodenextInt(bound), die Werte zwischen97und einschließlich122erzeugen soll
- das Array hat (nur) die Länge
-
Schreiben Sie dafür eine Methode
public static char[] createAndFillCharArray()- in dieser Methode erzeugen Sie das
char[]der Länge25, - ein
Random-Objekt, mit dem Sie unter Verwendung dernextInt(bound)-Methode zufällig Zahlen zwischen97und einschließlich122erzeugen, - die erzeugten
int-Werte konvertieren Sie mithilfe des(char)-Typecast-Operators nachchar, - dann befüllen Sie das
char[]→ passen Sie aber auf, dass Sie kein Zeichen hinzufügen, das bereits im Array enthalten ist → dazu benötigen Sie diecontains()-Methode:
- in dieser Methode erzeugen Sie das
-
Schreiben Sie eine Methode
public static boolean contains(char[] ca, char c). Diese gibt eintruezurück, wenncincaenthalten ist und einfalse, wenn nicht. -
Schreiben Sie eine Methode
public static char[] sort(char[] a). Diese gibt einchar[]zurück, welches sortiert ist. Das übergebene Arrayaist unsortiert. Siehe dazu Sortieren von Arrays. -
Schreiben Sie eine Methode
public static void print(char[] a), die ein übergebeneschar[]in der Formausgibt. Kennen wir aus Übung 8, aber gute Übung, es nochmal zu machen.
-
Geben Sie in Ihre
main()-Methode folgende Anweisungen ein:System.out.printf("%n%n----------------- Erzeugen ------------------%n%n"); char[] ca1 = createAndFillCharArray(); print(ca1); System.out.printf("%n%n----------------- Sortieren ------------------%n%n"); char[] ca2 = sort(ca1); print(ca2);Es sollten Ausgaben in der Form:
----------------- Erzeugen ------------------ [ o, g, f, p, a, c, s, i, e, q, h, l, t, r, w, z, v, x, y, u, b, j, k, m, n ] ----------------- Sortieren ------------------ [ a, b, c, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s, t, u, v, w, x, y, z ]erscheinen. Beachten Sie, dass die Einträge im Array zufällig erzeugt wurden. Beachten Sie außerdem, dass ein Buchstabe aus dem Alphabet fehlt, hier z.B.
d(das Array hat die Länge25, das Alphabet hat26Buchstaben).
- Wenn Sie das geschafft haben, dann haben Sie die Aufgabe erfüllt! Herzlichen Glückwunsch! Die folgende(n) Aufgabe(n) sind optional :
-
Schreiben Sie eine Methode
public static char getMissingLetter(char[] a). Dieser Methode wird ein durch die obige MethodecreateAndFillCharArray()erstellteschar-Array übergeben. Das Array hat also die Länge25hat und aus dem Alphabet fehlt genau ein kleiner Buchstabe. Finden Sie den Buchstaben und geben ihn zurück. -
Schreiben Sie eine Methode
public static void findWord(String word). Dieser Methode wird eine Zeichenkette übergeben, die nur aus Buchstaben besteht. Sie können annehmen, dass es nur kleine Buchstaben sind, Sie können aber erstmal dietoLowerCase()-Methode anwenden (siehe String). Rufen Sie für jedes Zeichen aus dem String die beiden MethodencreateAndFillCharArray()undgetMissingLetter()auf, bis das von dergetMissingLetter()-Methode zurückgegebene Zeichen dem Zeichen des Strings entspricht, das Sie gerade betrachten. Eine Ausgabe als Beispiel:P..........p (11) r.r (2) o..o (3) g............g (13) r..............................r (31) a........a (9) m..m (3) m...........................................................m (60) i....i (5) e.....e (6) rr (1) e......e (7) n............n (13)Die Ausgabe erfolgte durch den Aufruf von
findWord("Programmieren");. Ganz links in der Zeile steht immer das Zeichen des Strings, das gerade betrachtet wird. Dann kommen für jeden fehlgeschlagenen Versuch, durchgetMissingLetter()das'p' zurück zu bekommen, die Ausgabe eines Punktes. SolltegetMissingLetter()das'p'` zurückgeben, wird es ausgegeben und außerdem noch in Klammern die Anzahl der Versuche. Der Cursor wechselt in die nächste Zeile und das nächste Zeichen des Strings ist dran. -
Viel Spaß und viel Erfolg!
Aufgabe 8 (Abgabe bis 17.01.2024 24:00 Uhr)¶
Aufgabe 8 - SortedArray
-
Wir erstellen uns einen neuen Datentyp
SortedArray -
Idee: Ein Objekt dieser Klasse beschreibt (enthält) ein
int-Array, in dem- die Elemente aufsteigend sortiert sind und
- kein Element doppelt vorkommt.
Das Array ist stets genau so groß, so viele Elemente es enthält!
-
Erstellen Sie im package
aufgaben.aufgabe7eine KlasseSortedArrayohnemain()-Methode und eine KlasseSortedArrayTestmitmain()-Methode. -
In der Klasse
SortedArrayerstellen Sie eine Objektvariablesvom Typint[](private). -
Implementieren Sie für die Klasse
SortedArrayzwei verschiedene Konstruktoren- parameterlos → der Konstruktor erzeugt ein leeres Array
s(mit der Länge0) - mit einem Parameter (
int element) → der Konstruktor erzeugt ein einelementiges Arrays(mit der Länge1), wobeis[0]den Wert vonelementannimmt.
- parameterlos → der Konstruktor erzeugt ein leeres Array
-
Implementieren Sie eine Objektmethode
public boolean insert(int element). Diese Methode gibt einfalsezurück, wennelementbereits insenthalten ist. Dann wird daselementnicht dem Array hinzugefügt. Die Methode gibttruezurück, wennelementinseingefügt wurde. Umelementeinzufügen, wird ein neues Array fürserzeugt, in dem alle vorherigen Werte aussund das neueelement(an der richtigen Stelle einsortiert) enthalten sind. -
Implementieren Sie eine Objektmethode
public boolean delete(int element). Diese Methode gibt einfalsezurück, wennelementnicht insenthalten ist. Die Methode gibttruezurück, wennelementaussgelöscht wurde. Beachten Sie, dass nach Löschen aussdie Länge vonsum eins kleiner ist, als vor dem Löschen. Es muss also auch hier wieder ein neues Array erzeugt werden, welches nach dem Löschen dem "Wert" vonsentspricht. -
Implementieren Sie eine Objektmethode
public void print(), die das Arraysin der Form[ 4, 5, 9 ](Beispielwerte) ausgibt. -
Tipp:
- Um zu überprüfen, ob ein
int elementinsenthalten ist, sollten Sie sich eine Methodeboolean contains(int element)schreiben (diese kannprivatesein, wenn sie nur innerhalb der Klasse verwendet werden soll; sogenannte Servicemethode). - Angenommen, Sie haben zwei Arrays:
s = [ 4, 9 ]undcopy = [ 4, 5, 9], dann gilt nachs = copy;, dasss == [ 4, 5, 9 ].
- Um zu überprüfen, ob ein
-
Geben Sie in die
main()-Methode derSortedArrayTest-Klasse mindestens folgende Anweisungen ein:und führen Sie dieSystem.out.printf("%n%n------------------------- Test a1 -----------------------------------%n%n"); SortedArray a1 = new SortedArray(); a1.print(); a1.delete(5); a1.print(); a1.insert(5); a1.print(); a1.insert(7); a1.print(); a1.delete(5); a1.print(); a1.insert(6); a1.print(); a1.insert(4); a1.print(); a1.insert(8); a1.print(); a1.delete(8); a1.print(); a1.delete(6); a1.print(); System.out.printf("%n%n------------------------- Test a2 -----------------------------------%n%n"); SortedArray a2 = new SortedArray(9); a2.print(); a2.insert(5); a2.print(); a2.insert(9); a2.print(); a2.insert(5); a2.print(); a2.insert(4); a2.print(); a2.insert(4); a2.print(); a2.delete(5); a2.print(); a2.delete(9); a2.print(); a2.delete(4); a2.print(); a2.delete(4); a2.print();SortedArrayTest-Klasse aus. Es sollten folgende Augaben entstehen:------------------------- Test a1 ----------------------------------- [ ] [ ] [ 5 ] [ 5, 7 ] [ 7 ] [ 6, 7 ] [ 4, 6, 7 ] [ 4, 6, 7, 8 ] [ 4, 6, 7 ] [ 4, 7 ] ------------------------- Test a2 ----------------------------------- [ 9 ] [ 5, 9 ] [ 5, 9 ] [ 5, 9 ] [ 4, 5, 9 ] [ 4, 5, 9 ] [ 4, 9 ] [ 4 ] [ ] [ ] - Viel Spaß und viel Erfolg!