DCV 2023 09/Uebungen Weihnachtsferien

Aus CCWiki
Zur Navigation springen Zur Suche springen
Wir wünschen euch viel Spaß mit dieser Freizeitbeschäftigung. Genießt die freie Zeit und nützt diese auch zum programmieren üben!


Start der Selbstkontrolle

Schleifen

Aufgabe 1)

Zähle in einer for-Schleife rückwärts von 10 bis inklusive 0 und gib jede Zahl aus.

Ausgabe

10 9 8 7 6 5 4 3 2 1 0

Aufgabe 2)

Zähle in einer for-Schleife von -30 bis inklusive 30 und gib jede Zahl aus die ohne Rest durch 3 teilbar ist.

Ausgabe

-30
-27
-24
...
24
27
30

Aufgabe 3)

Zähle mit Hilfe einer while-Schleife und einer separaten Zählvariable von 0 bis inklusive 10 und gib die Zahlen aus. Wenn die Zahl größer als 5 ist mach 2 Zeilenumbrüche.

Ausgabe

0
1
2
3
4
5
6

7

8

9

10

Methoden

Diese 4 Aufgaben helfen dir später bei der Lösung von TicTacToe und 4 Gewinnt!!!


Aufgabe 1)

Erstelle eine Methode welche einen string und einen int Parameter erhält. Der angegebene string soll so oft wie beim int angegeben, in einer Zeile wiederholt ausgegeben und mit einem Whitespace getrennt werden.

Initialisiere Variablen für deine Parameter und gib diese dann der Methode weiter, damit du deine Methoden wieder verwenden kannst.

Aufruf

string symbol = "X";

int amount = 10;

PrintLineStipple(symbol, amount);


Ausgabe

X X X X X X X X X X

Aufgabe 2)

Erstelle eine Methode welche einen string und einen int Parmeter erhält. Der angegebene string soll so oft wie beim int angegeben in einer eigenen Zeile wiederholt werden. Trenne die Zeilen zusätzlich durch ein Linebreak.

Aufruf

string symbol = "X";

int amount = 3;

PrintRowStipple(symbol, amount);


Ausgabe

X

X

X

Aufgabe 3)

Erstelle eine Methode welche einen string und einen int Parameter erhält. Nun sollen mit diesen beiden Parametern die beiden Methoden aus den vorhergehenden Aufgaben aufgerufen werden. Die Methoden aus den vorhergehenden Aufgaben sollen nicht neu geschrieben werden.

Aufruf

string symbol = "X";

int amount = 3;

PrintStippleL(symbol, amount);


Ausgabe

X X X
X

X

X


Aufgabe 4)

Erstelle eine Methode welche eine Diagonale von variabler Größe und mit angegebene Zeichen ausgibt, weiters soll der Parameter backslash angegeben werden können. Wenn backslash wahr ist, soll die Diagonale von rechts Unten nach Links Oben gehen, ansonsten umgekehrt.

Aufruf:

PrintSlash("x", 3, true);

Ausgabe:

x
 x
  x

Aufruf:

PrintSlash("y", 3, false);

Ausgabe:  

#Diese Zeile gehört nicht zur Ausgabe! Leider verhaut es mir die Formatierung wenn die erste Zeile mit einem Leerzeichen beginnt :-|
  y
 y
y

Input

Aufgabe 1)

Lies einen string vom Benutzer ein und einen int. Die Zahl besagt wie oft der string ausgegeben werden soll. Wird ein leerer string oder ein ungültiger int eingegeben, so soll die Eingabe erneut erfolgen.

Erstelle eine Methode ReadString() und ReadNumber().

Eingabe

Bitte geben Sie einen Text ein:
>> Heute wird ein guter Tag
Wie oft soll der Text ausgegeben werden:
>> 3

Ausgabe

Heute wird ein guter Tag
Heute wird ein guter Tag
Heute wird ein guter Tag

Arrays

Array für Aufgabe 1 und 2.

int[] arr = new int[]{0, 1, 23, 5, 12, 4, 4, 2, 5, 2, 10};

int[] arr2 = new int[]{123, 19471, 1, 4, 15715, 15, 1, 5, 15, 1, -10, -100};

int[] arr3 = new int[]{478199, 7812973, 12387123, 12, 3, 123, 12, 3, 1, 3, 1, 3, 1, 8, 9, 15, 1, 5, 1, 5, 1, 5, 15, 1, 5, 0};


Aufgabe 1)

Erstelle eine Methode die ein int[] als Parameter erhält und das erste und letzte Element zu einem string zusammenfügt und zurückgibt. Verwende dazu die Beispielarrays in der Klasse und gib das Ergebnis für alle 3 Arrays aus.

Aufruf

PrintFirstAndLast(arr);

Ausgabe

First: 0, Last: 10


Aufgabe 2)

Ertelle jeweils eine Methode für Minimum (min), Maximum (max), und Durchschnitt (avg), welche den jeweiligen Wert für ein int[] berechnet und zurückgeben kann. Teste alle Methoden in der Start Methode mit allen gegebenen int[] der Klasse.

Erstelle eine Print Methode die einen string und einen int bekommt.

Beispiel Aufruf

PrintMyResult("Minimum",GetMin(arr));

Beispiel Ausgabe

Minimum: 0

Beispiel Aufruf

PrintMyResult("Maximum",GetMax(arr));

Beispiel Ausgabe

Maximum: 23


Aufgabe 3)

Erstelle eine Methode welche einen int als Parameter nimmt. Diese Methode soll ein int[] erstellen und das int[] mit den Zahlen von 0 bis inklusive der angegebenen Zahl befüllen und dann zurückgeben. Teste diese Methode in der Start Methode und gib das Array auf verschiede Arten aus (for-Schleife, foreach-Schleife und Console.WriteLine("[{0}]", string.Join(", ", arr)))

Aufruf

int[] arr = fillArr(10);
//Ausgabe arr

Ausgabe

0 1 2 3 4 5 6 7 8 9 10


Aufgabe 4)

Erstelle ein int[] und befülle es mit Zufallszahlen von 0 bis 100. Sortiere das gegebene int[] mit Hilfe von Bubblesort und gib das Array aus.

  1. Sortiere der Größe nach aufsteigend (Ascending)
  2. Sortiere der Größe nach absteigend (Descending)

Erstelle eine Neue, oder erweitere deine Methode! Diese soll nun zusätzlich zum int[] Parameter einen weiteren bool als Parameter erhalten. Dieser bool entscheidet, ob das int[] aufsteigend, oder absteigend sortiert wird.

String manipulation

Heute der 19.10.2021 wird ein sehr guter Tag. Zwar gibt es sowas wie einen Test, den 14 Leute schreiben, aber das ist doch egal!

Aufgabe 1)

Ersetze mit Hilfe von regulären Ausdrücken folgendes aus dem in der Klasse gegebenen string. Folgende Aufzählung ist als Ganzes zu betrachten.

  • a bis c durch X
  • f bis z durch Y
  • 1 bis 5 durch a
  • 4 bis 9 durch b

und gib den string, bei dem alles ersetzt wurde, aus.

Ausgabe

HeYYe deY ab.a0.a0aa YYYd eYY YeYY YYYeY TXY. ZYXY YYXY eY YYYXY YYe eYYeY TeYY, deY aa LeYYe YXYYeYXeY, XXeY dXY YYY dYXY eYXY!

Aufgabe 2)

Erstelle einen regulären Ausdruck der folgendem Sachverhalt entspricht und prüfe diesen in der Start Methode. Die Punkte gehören alle zum gleichen regulären Ausdruck und sollen nacheinander zutreffen:

  1. Drei oder mehr Kleinbuchstaben
  2. Eine Zahl größer als 0
  3. Zwei Zahlen
  4. Ein oder mehr Großbuchstaben


Aufruf          Console.WriteLine(Regex.IsMatch("abc100A", regex));          Ausgabe          true

Aufruf          Console.WriteLine(Regex.IsMatch("Abc100A", regex));          Ausgabe          true

Aufruf          Console.WriteLine(Regex.IsMatch("luke010A", regex));          Ausgabe          true

Aufruf          Console.WriteLine(Regex.IsMatch("test101ABCDE", regex));          Ausgabe          true

Aufruf          Console.WriteLine(Regex.IsMatch("test1ABCDE", regex));          Ausgabe          true

Kalender

Aufgabe 1)

Gib mit Hilfe der Calendar Api den Wochentag des aktuellen Tages inklusive Datum aus.

Ausgabe

DI 19.10.2021


Ende der Selbstkontrolle


Bonus Aufgaben

Wähle eine Bonus Aufgaben aus wenn du diese noch nicht erledigt hast.

Du kannst natürlich auch alle machen.

Achte beim Lösen der Aufgaben darauf, ...

  • sinvolle Methoden zu erstellen und gestalte deinen Code übersichtlich.
  • deine PrintMethode schön zu formatieren. (Spielfeld zeichnen, Farben implementieren)


Erweitere deine Spiellogik für TicTacToe und 4 Gewinnt

Auswahlmöglichkeiten:

  • Spieler Name
  • Spieler Farbe
  • Restart (wenn das Spiel zu ende ist)

Aufgabe1: GameOfLife

Conways Game of life

Aufgabe2: TicTacToe

TicTacToe

Aufgabe3: 4 in a Row

4 in a Row

Zusätzliche Bonus Aufgaben

Aufgabe: Türme von Hanoi

Finde eine programmatische Lösung für die Türme von Hanoi.

Als Datenstruktur wird ein 2-Dimensionales Array benötigt:

Die Größe des ersten Array ist 3 (entsprechend der Stäbe), befülle dieses mit der Anzahl der Scheiben.

Anzahl der Scheiben kann variieren. Starte mit 3 Scheiben und teste dann, ob dein Code auch funktioniert wenn du die Anzahl erhöhst.


int disks = 3;
int[][] hanoi = new int[3][]

Jede Scheibe wird durch eine Zahl reprästentiert, die dessen Größe beschreibt.

Folgende Methoden werden benötigt:

  • Spielfeld ausgeben
  • Spielfeld initialisieren
  • hanoiMove(int from, int to, int using, int count)
 * count == 1 // direct move
 * ansonstens 3 Schritte
     * hanoiMove(from, using, to, count - 1)
     * hanoiMove(from, to, using, 1) // Wirkliche Bewegung 
     * hanoiMove(using, to, from, count - 1)
Tip: Fibonacci

Aufgabe: Blackjack

Regeln: http://www.hitorstand.net/strategy.php (Wir machen ohne Split)

int[] deck = new int[52]; (initialisiert von 0, 1, 2 bis 51.)

Methoden:

  • Mischen mit swap
  • getColor() auf Basis value / 13
  • getFigure() auf Basis value % 13
  • getValue()
  • getValueHand() // zB: Summe von 3 Karten

Strategie für die Bank: Zieht bis < 17

Achte auf eine schöne Ausgabe!