DCV 2023 03/Selbstkontrolle Strukturierte Programmierung: Unterschied zwischen den Versionen
Sandro (Diskussion | Beiträge) |
Sandro (Diskussion | Beiträge) |
||
| Zeile 147: | Zeile 147: | ||
==== Aufgabe 1) ==== | ==== Aufgabe 1) ==== | ||
Erstelle eine '''Methode''' die ein {{JSL|int[]}} als Parameter erhält und das '''erste''' und '''letzte''' Element zu einem {{JSL|string}} zusammenfügt und zurückgibt. Verwende dazu die Beispielarrays in der Klasse und gib das Ergebnis für alle 3 Arrays aus. | Erstelle eine '''Methode''' die ein {{JSL|int[]}} als Parameter erhält und das '''erste''' und '''letzte''' Element zu einem {{JSL|string}} zusammenfügt und zurückgibt. Verwende dazu die Beispielarrays in der Klasse und gib das Ergebnis für alle 3 Arrays aus. | ||
'''Aufruf''' | '''Aufruf''' | ||
Version vom 27. Oktober 2023, 07:41 Uhr
Zeitlicher Ablauf
Ca. 3~6 Stunden
Viel Spaß und Erfolg
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
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
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 main Methode und gib das Array aus (egal wie, z.b.: Schleife, oder Arrays.toString(...))
Aufruf
int[] arr = fillArr(10);
//Ausgabe arr
Ausgabe
0 1 2 3 4 5 6 7 8 9 10
Aufgabe 4)
Sortiere das in der Klasse gegebene int[] mit Hilfe von Bubblesort und gib das Array aus. Ob aufsteigend oder absteigend Sortiert bleibt dir überlassen.
Kalender
Siehe Package: at/digitialcampus/codingcampus/calendar/
Aufgabe 1)
Gib mit Hilfe der Calendar Api den Wochentag des aktuellen Tages inklusive Datum aus.
Ausgabe
DI 19.10.2021
String manipulation
Siehe Package: at/digitialcampus/codingcampus/stringmanipulation/
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 main Methode. Die Punkte gehören alle zum gleichen regulären Ausdruck und sollen nacheinander zutreffen:
- Drei oder mehr Kleinbuchstaben
- Eine Zahl größer als 0
- Zwei Zahlen
- Ein oder mehr Großbuchstaben
Aufruf "abc100A".matches(regex); Ausgabe true
Aufruf "Abc100A".matches(regex); Ausgabe false
Aufruf "luke010A".matches(regex); Ausgabe false
Aufruf "test101ABCDE".matches(regex); Ausgabe true
Aufruf "test1ABCDE".matches(regex); Ausgabe false
Datenströme
Siehe Package: at/digitialcampus/codingcampus/streams/
Die Einlesemethode in allen Aufgaben ist frei wählbar
Aufgabe 1)
Lies die Datei assets/file.txt in einen String ein und gib diesen anschließend aus.
Aufgabe 2)
Lies die Datei assets/file.txt in einen String ein und gib die Anzahl der Worte des String aus.
Aufgabe 3)
Lies die Datei assets/file.txt in einen String ein, zerlege diesen in Worte und sortiere diese mittels Bubblesort lexikographisch (string.compareTo(otherString) und gib das sortierte String[] aus.
Aufgabe 4) Bonus
Sortiere wie in der vorhergehenden Aufgabe. Bei der Ausgabe sollen Wörter nicht mehrfach ausgegeben werden, weiters füge bei jedem Wort die Anzahl der vorkommnisse hinzu.