Strukturierte Programmierung Uebungen: Unterschied zwischen den Versionen
Drlue (Diskussion | Beiträge) |
Drlue (Diskussion | Beiträge) |
||
| Zeile 195: | Zeile 195: | ||
Random random = new Random(); | Random random = new Random(); | ||
... | ... | ||
random.nextInt[Upper bound]) | int randomNumber = random.nextInt([Upper bound]); | ||
}} | }} | ||
| Zeile 201: | Zeile 201: | ||
Erstelle ein {{JSL|int[]}} und befülle es mit Zufallszahlen von '''-50''' bis '''50''' und gib es mit Hilfe einer '''foreach-Schleife''' aus. | Erstelle ein {{JSL|int[]}} und befülle es mit Zufallszahlen von '''-50''' bis '''50''' und gib es mit Hilfe einer '''foreach-Schleife''' aus. | ||
Bubblesort | ==== Aufgabe 3) ==== | ||
Erstelle ein | Erstelle ein {{JSL|int[]}} und befülle es mit Zufallszahlen von '''0''' bis '''1000'''. Erstelle jeweils eine Methode für das '''Minimum''', das '''Maximum''' und den '''Durchschnitt'''. Die Methoden sollen jeweils den Wert zurückgeben (nicht Ausgeben). In der {{JSL|main}} Methode Rufe die Methoden mit den Zufallszahlen auf und gib diese aus. | ||
==== Aufgabe 4) Bubblesort Zahlen ==== | |||
Erstelle ein {{JSL|int[]}} und sortiere es mit einem selbsterstellten '''Bubblesort Algorithmus''' und gib es dann aus. Der '''Bubblesort Algorithmus''' soll in einer eigenen Methode implementiert werden. Der Aufruf und die Ausgabe erfolgt in der {{JSL|main}} Methode. | |||
# Sortiere der Größe nach aufsteigend (Ascending) | |||
# Sortiere der Größe nach absteigend (Descending) | |||
Verwende das gegebene String Array und sortiere es mit einem selbsterstellten Bubblesort Algorithmus und gib es aus. Tip.: (Strings können mit der Instanz Methode compareTo der String Klasse verglichen werden: "a".compareTo("b")) | Verwende das gegebene String Array und sortiere es mit einem selbsterstellten Bubblesort Algorithmus und gib es aus. Tip.: (Strings können mit der Instanz Methode compareTo der String Klasse verglichen werden: "a".compareTo("b")) | ||
Version vom 15. Oktober 2021, 18:59 Uhr
Übungsaufgaben
Im folgenden finden sich verschiedene Übungsaufgaben für den Bereich der Strukturierten Programmierung in Java.
Übungsaufgaben Strukturierte Programmierung
Schleifen
Aufgabe 1)
Zähle in einer Schleife von 0 bis inklusive 10 und gib die Zahlen aus.
- Verwende dazu eine for-Schleife
- Verwende dazu eine while-Schleife und erstelle eine separate Zählvariable
Aufgabe 2)
Zähle in einer Schleife von 0 bis inklusive 10 gib nur jede gerade Zahl aus.
- Verwende um zu prüfen ob es eine gerade Zahl ist den Modulo Operator
- Modifiziere die Zählvariable so, dass die Zählvariable nur jede gerade Zahlen enthält
Aufgabe 3)
Zähle in einer Schleife rückwärts von 10 bis inklusive -10 und gib die Zählvariable aus.
Aufgabe 4)
Zähle in einer Schleife von 0 bis exklusive 10 und gib die Zählvariable aus.
Methoden & Schleifen
Wähle immer einen sinnvollen Methodennamen der beschreibt was die Methode macht und überlege dir Rückgabewert und Übergabeparameter gut. Teste deine Methoden ausgiebig. Wenn eine Methode mehr als nur einen Zweck erfüllt überlege ob sie in weitere Methoden unterteilt werden kann.
Aufgabe 1)
Erstelle eine Methode die eine bestimmte Anzahl parameterisierbarer Zeichen einer Zeile ausgibt.
Aufruf:
printChars("x", 10);
Ausgabe:
xxxxxxxxxx
Aufgabe 2)
Erstelle eine Methode welche ein Quader mit variabler Größe und mit angegebenem Zeichen ausgibt.
Aufruf:
printSquare(10, "x");
Ausgabe:
xxxxxxxxxx
x x
x x
x x
x x
x x
x x
x x
x x
xxxxxxxxxx
Aufruf:
printSquare(3, "A");
Ausgabe:
AAA
A A
AAA
Aufgabe 3)
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", 4, 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
y
Aufgabe 4)
Erstelle eine Methode welche ein X von variabler Größe und mit angegebene Zeichen ausgibt.
- Löse das Problem wie es dir gefällt
- Löse das Problem mit nur zwei ineinander verschachtelten Schleifen
Aufruf:
printX('x', 5);
Ausgabe:
x x
x x
x
x x
x x
Aufgabe 5)
Erstelle eine Methode welche ein Dreick von variabler Größe und mit angegebene Zeichen ausgibt. Dabei sollen die angegebene Größe die Höhe des Dreicks sein. Nimm an dass die Zahl immer Ungerade ist.
Aufruf:
printTriangle("x", 3);
Ausgabe:
#Diese Zeile gehört nicht zur Ausgabe! Leider verhaut es mir die Formatierung wenn die erste Zeile mit einem Leerzeichen beginnt :-|
x
x x
xxxxx
Aufruf:
printTriangle("x", 5);
Ausgabe:
#Diese Zeile gehört nicht zur Ausgabe! Leider verhaut es mir die Formatierung wenn die erste Zeile mit einem Leerzeichen beginnt :-|
x
x x
x x
x x
xxxxxxxxx
Aufruf:
printTriangle("x", 1);
Ausgabe:
x
Aufgabe 6)
Erstelle eine Methode welche einen Rhombus von variabler Größe und mit angegebene Zeichen ausgibt. Die Größe soll dabei die Höhe des Rhombus sein.
- Löse das Problem wie es dir gefällt
- Löse das Problem mit nur zwei ineinander verschachtelten Schleifen
Aufruf:
printRhombus("x", 7);
#Diese Zeile gehört nicht zur Ausgabe! Leider verhaut es mir die Formatierung wenn die erste Zeile mit einem Leerzeichen beginnt :-|
x
x x
x x
x x
x x
x x
x
Input
Im folgenden werden verschiedene Aufgaben zum Lesen von Userinput gestellt. Erstelle wo nötig Methoden um die Komplexität gering zu halten.
Aufgabe 1)
Lies mit Hilfe des berühmten Scanners einen String des Benutzers ein und gib diesen aus.
Aufgabe 2)
Lies mit Hilfe des berühmten Scanners einen int des Benutzers ein und gib diese aus.
- Wird keine Zahl eingegeben kann das Programm abstürzen
- Frag solange nach einer Zahl bis auch eine eingegeben wurde, das Programm darf bei Fehleingabe nicht abstürzen
Aufgabe 3) Taschenrechner
Erstelle einen Taschenrechner. Lies mit Hilfe berühmten Scanners vom Benutzer zuerst einen float ein, dann den Operator (+,-,*,^,/), dann wieder einen float ein. Nach dem einlesen führe die gewünschte Rechenoperation aus. Bei Fehleingaben egal ob bei den Zahlen oder beim Operator, soll erneut nachgefragt werden.
Aufgabe 4) Taschenrechner extended
Erweitere den Taschenrechner aus der vorhergehenden Aufgabe so, dass nach der Berechnung nachgefragt wird, ob eine neue Berechnung stattfinden soll, falls nicht, soll das Programm beendet werden.
Arrays
Aufgabe 1)
Erstelle ein int[] und befülle es mit Zufallszahlen von 0 bis 100 und gib es mitHilfe einer foreach-Schleife aus.
Random random = new Random();
...
int randomNumber = random.nextInt([Upper bound]);
Aufgabe 2)
Erstelle ein int[] und befülle es mit Zufallszahlen von -50 bis 50 und gib es mit Hilfe einer foreach-Schleife aus.
Aufgabe 3)
Erstelle ein int[] und befülle es mit Zufallszahlen von 0 bis 1000. Erstelle jeweils eine Methode für das Minimum, das Maximum und den Durchschnitt. Die Methoden sollen jeweils den Wert zurückgeben (nicht Ausgeben). In der main Methode Rufe die Methoden mit den Zufallszahlen auf und gib diese aus.
Aufgabe 4) Bubblesort Zahlen
Erstelle ein int[] und sortiere es mit einem selbsterstellten Bubblesort Algorithmus und gib es dann aus. Der Bubblesort Algorithmus soll in einer eigenen Methode implementiert werden. Der Aufruf und die Ausgabe erfolgt in der main Methode.
- Sortiere der Größe nach aufsteigend (Ascending)
- Sortiere der Größe nach absteigend (Descending)
Verwende das gegebene String Array und sortiere es mit einem selbsterstellten Bubblesort Algorithmus und gib es aus. Tip.: (Strings können mit der Instanz Methode compareTo der String Klasse verglichen werden: "a".compareTo("b")) String[] names = new String[]{"Plamena", "Sadaaq", "Eray", "Gerri", "Stefan", "Lena", "Danny", "Ömer", "Stjepan", "Sandro", "Bartosz", "Ingo", "Rauan", "Mahir", "Lukas", "Niklas", "Gyula"};
String Operationen
Regex replace und split
Datenströme