Benutzer-Werkzeuge

Webseiten-Werkzeuge


arrays:start

Arrays (Felder)


Oft möchte man viele gleichartige Daten (d.h. Daten mit demselben Datentyp) speichern, z.B. die ersten 1000 Primzahlen. Stell Dir vor, Du müsstest für jede dieser Zahlen einen eigenen Variablennamen vergeben:

int p1 = 2;
int p2 = 3;
int p3 = 5;
...
int p1000 = ?!?

Oder stell Dir vor, Du möchtest dann diese 1000 gespeicherten Zahlen kommasepariert ausgeben (2, 3, 5, 7, …):

println(p1 + ", " + p2 + ", " + p3 + ", " + p4 + ", " + ... + p1000);

Kein Mensch möchte das tippen müssen. Das muss doch besser gehen!

Ein Array (deutsch: "Feld") ist ein Datentyp, der es gestattet, viele gleichartige Daten (d.h. Daten mit demselben Datentyp) zu speichern und durch Angabe eines Indizes (d.h. ihrer Position innerhalb des Feldes) schnell auf sie zuzugreifen.

Beispiel:
Lege ein Feld an, in dem 10 int-Werte gespeichert werden können und nenne dieses Feld test.

int[] test = new int[10]; 

Dabei ist int[] der Datentyp "Feld von int-Werten". Der Term new int[10] reserviert einen Speicherbereich, in dem 10 int-Werte Platz haben, füllt ihn mit zehn 0-Werten und liefert eine Referenz darauf zurück. Nach der Zuweisung (=) zeigt die Variable test auf diesen Speicherbereich.

Die zehn Werte nennt man Feldelemente. Sie werden mit den Indizes 0 bis 9 durchnummeriert. Du kannst Dir das Feld so vorstellen:

Zugriff auf die Feldelemente:

  • test[3] = 12; weist dem vierten(!) Feldelement den Wert 12 zu. Das Feld sieht danach so aus:


  • int a = test[0]; kopiert den Wert des ersten Feldelements in die Variable a.

Beispiel 0: Größte Zahl finden

Schreibe ein Programm, das ein Int-Array mit 100 einträgen deklariert reserviert, dann die 100 Einträge mit Zufallszahlen von 1 bis 1000 füllt, anschließend die größte dieser 1000 Zahlen ermittelt und diese ausgibt.

Beispiel 1: Rätsel

Was gibt das folgende Programm aus? Denke zuerst nach, bevor Du es ausführst!

Ansicht eines Arrays beim Debuggen Öffne vor dem Ausführen den Reiter "Variablen" und führe dann das Programm schrittweise aus ("Step over": ). Du kannst so Schritt für Schritt sehen, wie sich die Werte des Feldes verändern und das Programm so ganz leicht verstehen.

Klicke rechts auf auf die kleine Grafik, dann wird Dir das Vorgehen als animated gif gezeigt!

Beispiel 2: Namenspeicher

Wir schreiben ein kleines Programm, das den Benutzer nach 5 Namen fragt und diese in einem Array speichert. Anschließend kann der Benutzer Indizes von 0 - 4 eingeben und bekommt den zugehörigen Namen vom Computer genannt.

Natürlich ist dieses Programm noch nicht wirklich praktisch verwendbar, aber Du bekommst ein Gefühl dafür, wozu Arrays gut sind.

Beispiel 3: Größter Wert (Fingerübung)

  • a) Deklariere ein Feld mit dem Bezeichner werte, das 10 double-Werte enthält und fülle es mit den Werten sin(0), sin(1), …, sin(9). Verwende dazu eine while- oder for-Wiederholung.
  • b) Ergänze Dein Programm so, dass es anschließend den größten der 10 Werte findet und ausgibt!

Beispiel 4: Absolute und relative Häufigkeiten beim Würfeln

Der Benutzer nennt eine Anzahl n. Der Computer soll n-mal würfeln und dabei mitzählen, wie oft jede der Zahlen 1 bis 6 vorgekommen ist. Am Ende soll er die absoluten und relativen Häufigkeiten der sechs Zahlen ausgeben.

Was sind absolute und relative Häufigkeiten?

Stell' Dir vor, Du würfelst 50-mal. Dabei erhältst Du 7-mal die Augenzahl 6. Dann nennt man 7 die absolute Häufigkeit des Ereignisses "6 gewürfelt" und $7/50$ (also 14%) die relative Häufigkeit dieses Ereignisses.

Strategie:
Wir speichern die Anzahl der Einsen, Zweien, Dreien, … Sechsen in einem int-Feld mit 6 Werten

Beispiel 5: Selection Sort

Selection sort Eine gute Beschreibung dieses Algorithmus findest Du in Wikipedia. Wir programmieren eine etwas einfachere Variante:

  • 1. Eine Variable start zeigt zunächst auf das erste Element des Arrays (index 0)
  • 2. Vergleiche jeden Wert rechts von start mit dem Wert bei start. Falls ersterer kleiner ist, dann vertausche beide
  • 3. Erhöhe start um 1. Falls start dann noch nicht aufs letzte Element des Arrays zeigt, dann fahre bei 1. fort.

Die ersten Schritte des Algorithmus siehst Du hier an einem Beispiel:

Aufgabe 1: Zweierpotenzen (Fingerübung)

  • a) Deklariere ein Feld test mit 10 int-Werten und fülle es mit den Zweiterpotenzen 1, 2, 4, 8, 16, … 512. Verwende dazu eine while- oder for-Wiederholung!
  • b) Erweitere das Programm so, dass es anschließend alle Werte ausgibt.
  • c) Erweitere das Programm so, dass es - wiederum anschließend - die Summe aller Feldwerte berechnet und ausgibt.

Tipp: Falls Du Dich mit der Berechnung der Zweierpotenzen schwer tust, findest Du hier ein Programm, das die Zweierpotenzen auf dem Bildschirm ausgibt.

Hier geht's zur Lösung!

Aufgabe 2: Listenumkehrer

Schreibe ein Programm, das es dem Benutzer ermöglicht, 5 Namen einzugeben, und diese 5 Namen am Ende in umgekehrter Reihenfolge ausgibt.

Hier geht's zur Lösung!

Aufgabe 3 (Sternchenaufgabe): Das Sieb des Eratosthenes

Das Sieb des Eratosthenes ist ein sehr schneller Algorithmus zum Finden von Primzahlen, den Du aus dem Mathematikunterricht der Jahrgangsstufe 5 kennst. Falls Du Dich nicht mehr genau erinnerst, hier ein kurzes Erklärvideo dazu:

Schreibe ein Programm, das die Primzahlen bis 100 000 mit Hilfe des Sies des Eratosthenes ermittelt und ausgibt!

Strategie:

  • Deklariere ein Feld gestrichen von 100 001 Werten des Datentyps boolean. gestrichen[i] soll angeben, ob das Zahlenfeld mit der Zahl i "gestrichen" ist.
  • Setze gestrichen[0] = true und gestrichen[1] = true, denn 0 und 1 sind keine Primzahlen
  • Jetzt bis Du dran! Hier noch ein paar kleine Tipps:
    • Du wirst zwei ineinandergeschachtelte Wiederholungen brauchen.
    • Die Wurzel von 100 000 erhältst Du so: Math.sqrt(100000)

Hier geht's zur Lösung!

Aufgabe 4 Erweiterung des Sieb des Eratosthenes

Erweitere das Programm von Aufgabe 3 so,

  • a) dass der Benutzer zu Beginn eingeben kann, bis zu welcher Obergrenze die Primzahlen gesucht werden sollen.
  • b) dass es nach der Ermittlung der Primzahlen alle Primzahlzwillinge im Feld sucht und ausgibt.

Zwei Primzahlen, die den Abstand 2 haben, nennt man ein Primzahlzwilling, z.B. [3 und 5], [5 und 7], [11 und 13], [17 und 19] usw.
Man vermutet, dass es unendlich viele Primzahlzwillinge gibt, dies ist aber bis heute nicht bewiesen.

Hier geht's zur Lösung!

Aufgabe 5: Bubble Sort

Ein Feld mit 10 ganzen Zahlen soll mit Zufallszahlen (von 1 bis 100) belegt und ausgegeben werden. Anschließend soll der Rechner es der Größe nach aufsteigend sortieren und erneut ausgeben. Zum Sortieren verwenden wir den Bubble Sort-Algorithmus. Hier eine kurze Erklärung:

Aufgabe 6

Schreibe ein Programm, das ein Feld mit 10 zufälligen ganzen Zahlen von 1 bis 100 füllt und ausgibt. Danach soll folgendes gemacht werden:

  • a) Das Programm soll die größte der 10 Zahlen ausgeben.
  • b) Das Programm soll die Summe der 10 Zahlen ausgeben.
  • c) Das Programm soll untersuchen, ob das Feld mindestens zwei gleiche Zahlen enthält und dann ausgeben "Zwei gleiche Zahlen gefunden!" oder "Das Feld enthält lauter unterschiedliche Zahlen.".
  • d) Das Programm soll die Reihenfolge der Zahlen im Feld umkehren, aus dem Feld [12, 3, 44, 8, 10, 1, 90, 50, 40, 30] soll also das Feld [30, 40, 50, 90, 1, 10, 8, 44, 3, 12] werden.

Hier geht's zu den Lösungen!

types/arrays/start.txt · Zuletzt geändert: 2022/03/22 14:46 von Martin Pabst Seiten-Werkzeuge Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki

arrays/start.txt · Zuletzt geändert: 2024/01/23 13:19 von Martin Pabst

Donate Powered by PHP Valid HTML5 Valid CSS Driven by DokuWiki