Programmiertechnik: Unterschied zwischen den Versionen

Aus SibiWiki
Zur Navigation springen Zur Suche springen
 
(19 dazwischenliegende Versionen desselben Benutzers werden nicht angezeigt)
Zeile 2: Zeile 2:
[[Kategorie:Informatik-EF]]
[[Kategorie:Informatik-EF]]


Auf dieser Seite werden anhand von Kara grundlegende Programmiertechniken vorgestellt.
Auf dieser Seite werden anhand von Kara '''grundlegende Programmiertechniken''' vorgestellt.
 
Die Grundlagen der '''Java-Syntax''' werden auf folgender Seite vorgestellt: '''[[Java_Basis-Sprachelemente]]'''
 
=Methoden, die n-mal etwas tun=
''Mit '''n-mal''' ist gemeint, dass '''bekannt''' ist, wie oft die Wiederholung ausgeführt werden soll.
 
Dafür braucht man eine '''Wiederhole n-mal'''-Schleife. In Java kann man das mit <code>for</code> realisieren.
 
==Beispiel==
Kara soll eine Linie von 20 Kleeblättern legen.
 
{| class="wikitable"
! Programmbeschreibung !! Java Quelltext
|-
|
  {|style="border-style: solid; border-width: 0px;"
    | Methode zwanzigerLinieLegen()
    {|style="border-style: solid; border-width: 1px 0px 1px 1px; margin: 5px"
      | Wiederhole 20-mal
      {|style="border-style: solid; border-width: 1px 0px 1px 1px; margin: 5px"
        | lege ein Blatt<br/>gehe einen Schritt
      |}
    |}
  |}
||
  public void zwanzigerLinieLegen()
  {
    '''for(int i=0; i<20; i++)
    {
        kara.putLeaf();
        kara.move();
    }
  }
|}


=Methoden, die etwas tun, bis ein Ziel erreicht wird=
=Methoden, die etwas tun, bis ein Ziel erreicht wird=
Zeile 9: Zeile 43:
In der Regel haben diese Methoden folgenden Aufbau:
In der Regel haben diese Methoden folgenden Aufbau:
* Eine Schleife, die so lange läuft, bis das "Ziel" erreicht ist<br>In der Schleife passiert folgendes:
* Eine Schleife, die so lange läuft, bis das "Ziel" erreicht ist<br>In der Schleife passiert folgendes:
** Es wird "nachgedacht", was als nächster Schritt zu tun ist. (Das kann kompliziert sein...)
** Es wird "nachgedacht". (Das kann kompliziert sein...)
** '''Nach''' dem Nachdenken: Der Schritt wird ausgeführt.
** '''Nach''' dem Nachdenken: Ein Schritt in Richtung Ziel wird ausgeführt


'''Wichtig''' ist dabei, dass '''in jedem Schleifendurchlauf genau ein Schritt''' ausgeführt wird, und das erst nach dem "Nachdenken"!
'''Wichtig''' ist dabei, dass '''in jedem Schleifendurchlauf genau ein Schritt''' ausgeführt wird, und das erst '''nach''' dem "Nachdenken"!


Dadurch wird die Programmierung viel einfacher!
Dadurch wird die Programmierung viel einfacher!
Zeile 28: Zeile 62:
|-
|-
|
|
   '''Methode rundUmDenWald()'''
   {| style="border-style: solid; border-width: 0px;"
  &lceil;&macr;&macr;&macr;&macr;&macr;&macr;  
    | '''Methode rundUmDenWald()'''
  &#124;  Solange Kara nicht auf einem Blatt steht
    {| style="border-style: solid; border-width: 3px 0px 3px 3px; margin: 5px"
  &#124;  &lceil;&macr;&macr;&macr;&macr;&macr;&macr;
      | Solange Kara nicht auf einem Blatt steht
  &#124;  &#124; '''''(Nachdenken!)'''''
      {| style="border-style: solid; border-width: 2px 0px 2px 2px; margin: 5px"
  &#124;  &#124;  wenn kein Baum rechts ist
        | '''''(Nachdenken!)'''''<br>wenn kein Baum rechts ist
  &#124;  &#124;  &lceil;&macr;&macr;&macr;&macr;&macr;&macr;  
        {| style="border-style: solid; border-width: 1px 0px 1px 1px; margin: 5px"
  &#124;  &#124;  &#124;  drehe dich nach rechts
            | drehe dich nach rechts
  &#124;  &#124;  &lfloor; &#822; &#822; &#822; &#822; &#822; &#822;
        |} sonst
  &#124;  &#124;  sonst
        {| style="border-style: solid; border-width: 1px 0px 1px 1px; margin: 5px"
  &#124;  &#124;  &#124;&macr;&macr;&macr;&macr;&macr;&macr;
            | solange ein Baum vorne ist
  &#124;  &#124;  &#124;  wenn ein Baum vorne ist
            {| style="border-style: solid; border-width: 1px 0px 1px 1px; margin: 5px"
  &#124;  &#124;  &#124;  &lceil;&macr;&macr;&macr;&macr;&macr;&macr;
              | drehe dich nach links
  &#124; &#124; &#124;  &#124;  drehe dich nach links
            |}
  &#124;  &#124;  &#124;  &#124;  wenn ein Baum vorne ist
        |} <br/>'''''(Schritt ausführen!)'''''<br/>gehe einen Schritt
  &#124;  &#124;  &#124;  &#124;  &lceil;&macr;&macr;&macr;&macr;&macr;&macr;  
      |}
  &#124;  &#124;  &#124;  &#124;  &#124;  drehe dich nach links
    |}
  &#124;  &#124;  &#124;  &#124;  &lfloor; &#822; &#822; &#822; &#822; &#822; &#822;
   |}
  &#124;  &#124;  &#124;  &lfloor; &#822; &#822; &#822; &#822; &#822; &#822;
||
  &#124;  &#124;  &lfloor; &#822; &#822; &#822; &#822; &#822; &#822;
  &#124;  &#124;
  &#124;  &#124; '''''(Schritt ausführen!)'''''
  &#124;  &#124;  gehe einen Schritt
  &#124;  &lfloor; &#822; &#822; &#822; &#822; &#822; &#822;
   &lfloor; &#822; &#822; &#822; &#822; &#822; &#822;
||  
   public void rundUmDenWald()
   public void rundUmDenWald()
   {
   {
Zeile 65: Zeile 92:
         else
         else
         {
         {
           if(kara.treeFront())
           while(kara.treeFront())
           {
           {
               kara.turnLeft();
               kara.turnLeft();
              if(kara.treeFront())
              {
                kara.turnLeft();
              }
           }
           }
         }
         }
 
     
         // '''''(Schritt ausführen!)'''''
         // '''''(Schritt ausführen!)'''''
         kara.move();
         kara.move();
Zeile 100: Zeile 123:
|-
|-
|
|
   '''Methode zaehleBlaetter()''': ''gibt eine Zahl zurück''
   {|style="border-style: solid; border-width: 0px;"
  &lceil;&macr;&macr;&macr;&macr;&macr;&macr;  
    | '''Methode zaehleBlaetter()''': ''gibt eine Zahl zurück''
  &#124;  Setze ergebnis auf 0
    {|style="border-style: solid; border-width: 2px 0px 2px 2px; margin: 5px"
  &#124;  Solange Kara auf einem Blatt steht
      | Setze ergebnis auf 0<br/>Solange Kara auf einem Blatt steht
  &#124; &lceil;&macr;&macr;&macr;&macr;&macr;&macr;
      {|style="border-style: solid; border-width: 1px 0px 1px 1px; margin: 5px"
  &#124;  &#124; erhöhe ergebnis um 1
        | erhöhe ergebnis um 1<br/>gehe einen Schritt
  &#124;  &#124; gehe einen Schritt
      |} gib ergebnis zurück;
  &#124;  &lfloor; &#822; &#822; &#822; &#822; &#822; &#822;
    |}
  &#124;  gib ergebnis zurück;
   |}
   &lfloor; &#822; &#822; &#822; &#822; &#822; &#822;
||  
||  
   public int zaehleBlaetter()
   public int zaehleBlaetter()
Zeile 137: Zeile 159:
# Jetzt das Gesamtproblem programmieren!
# Jetzt das Gesamtproblem programmieren!


==Beispiel==
==Beispiel 1: Gebirge==
[[File:Kara-himalaya.png|thumb|Kara soll in einem Tal das Kleeblatt finden|773px]]
[[File:Kara-himalaya.png|thumb|Kara soll in einem Tal das Kleeblatt finden|773px]]
Kara soll über das Gebirge klettern, bis sie in einem Tal ein Kleeblatt findet.
Kara soll über das Gebirge klettern, bis sie in einem Tal ein Kleeblatt findet.
Zeile 144: Zeile 166:
Man sieht, dass Kara immer abwechselnd bergauf und bergab gehen muss!
Man sieht, dass Kara immer abwechselnd bergauf und bergab gehen muss!
Daher bietet es sich an, das Gesamtproblem mithilfe der folgenden zwei Methoden zu programmieren:
Daher bietet es sich an, das Gesamtproblem mithilfe der folgenden zwei Methoden zu programmieren:
* <code>aufDenGipfel()</code>
* <code>zumGipfel()</code>
* <code>insTal()</code>
* <code>insTal()</code>


Zeile 154: Zeile 176:
|-
|-
|
|
 
  {|style="border-style: solid; border-width: 0px;"
  '''Methode sucheKleeblatt()'''
    | '''Methode sucheKleeblatt()'''
  &lceil;&macr;&macr;&macr;&macr;&macr;&macr;  
    {|style="border-style: solid; border-width: 2px 0px 2px 2px; margin: 5px"
  &#124;  Solange Kara '''nicht''' auf einem Blatt steht
      | Solange Kara '''nicht''' auf einem Blatt steht
  &#124;  &lceil;&macr;&macr;&macr;&macr;&macr;&macr;
      {|style="border-style: solid; border-width: 1px 0px 1px 1px; margin: 5px"
  &#124;  &#124;  zumGipfel()
        | zumGipfel()<br/>insTal()
  &#124;  &#124;  insTal()
      |}
  &#124;  &lfloor; &#822; &#822; &#822; &#822; &#822; &#822;
    |}
   &lfloor; &#822; &#822; &#822; &#822; &#822; &#822;
   |}
|}
|}


Zeile 168: Zeile 190:
''Für die Teilprobleme wird hier nur die Programmierung angegeben.''
''Für die Teilprobleme wird hier nur die Programmierung angegeben.''


<code>
<code>
   '''public void zumGipfel()'''
   '''public void zumGipfel()'''
   {
   {
Zeile 180: Zeile 202:
     }
     }
   }
   }
</code>
 
 
 
<code>
   '''public void insTal()'''
   '''public void insTal()'''
   {
   {
Zeile 195: Zeile 214:
     }
     }
   }
   }
</code>
</code>
 


===Programmierung der Hauptmethode===
===Programmierung der Hauptmethode===
Zeile 208: Zeile 226:
|-
|-
|
|
 
  {|style="border-style: solid; border-width: 0px;"
  '''Methode sucheKleeblatt()'''
    | '''Methode sucheKleeblatt()'''
  &lceil;&macr;&macr;&macr;&macr;&macr;&macr;  
    {|style="border-style: solid; border-width: 2px 0px 2px 2px; margin: 5px"
  &#124;  Solange Kara '''nicht''' auf einem Blatt steht
      | Solange Kara '''nicht''' auf einem Blatt steht
  &#124;  &lceil;&macr;&macr;&macr;&macr;&macr;&macr;
      {|style="border-style: solid; border-width: 1px 0px 1px 1px; margin: 5px"
  &#124;  &#124;  zumGipfel()
        | zumGipfel()<br/>insTal()
  &#124;  &#124;  insTal()
      |}
  &#124;  &lfloor; &#822; &#822; &#822; &#822; &#822; &#822;
    |}
   &lfloor; &#822; &#822; &#822; &#822; &#822; &#822;
   |}
|
|
   '''public void sucheKleeblatt()'''
   '''public void sucheKleeblatt()'''
Zeile 225: Zeile 243:
         insTal();
         insTal();
     }
     }
  }
|}
==Beispiel 2: Wintervorrat==
[[File:Kara-wintervorrat-vorher.png|thumb|vorher|413px]]
[[File:Kara-wintervorrat-nachher.png|thumb|nachher|409px]]
Kara soll bis zur Höhle gehen und alle Kleeblätter aufsammeln.
Dann soll Kara die gesammelten Kleeblätter in der Höhle ablegen und sich darüber setzen.
===Zerlegung===
Das Problem besteht aus mehreren Teilproblemen die nacheinander abgearbeitet werden:
* <code>blaetterSammeln()</code>: <br>''Diese Methode gibt die Zahl der gesammelten Blätter zurück!''<br>''Danach dreht sich Kara nach rechts.''
* <code>bisZumBaumGehen()</code><br>''Danach dreht sich Kara zweimal nach rechts.''
* <code>blaetterLegen(int anzahl)</code><br>''Dieser Methode wird die Anzahl der gesammelten Blätter übergeben.''
===Programmbeschreibung der Hauptmethode===
{| class="wikitable"
! Programmbeschreibung
|-
|
  {|style="border-style: solid; border-width: 0px;"
    | '''Methode wintervorratAnlegen()'''
    {|style="border-style: solid; border-width: 2px 0px 2px 2px; margin: 5px"
        | ''Es wird die Variable blaetterZahl gebraucht!''<br/>blaetterZahl = blaetterSammeln()<br/>nach rechts drehen<br/>bisZumBaumGehen()<br/>zweimal nach rechts drehen<br/>blaetterLegen(blaetterZahl)
    |}
  |}
|}
===Programmierung der Teilprobleme===
''Für die Teilprobleme wird hier nur die Programmierung angegeben.''
<code>
  '''public int blaetterSammeln()'''
  {
    int ergebnis = 0;
    while(kara.treeRight())
    {
        // "Nachdenken"
        if(kara.onLeaf())
        {
            kara.removeLeaf();
            ergebnis = ergebnis + 1;
        }
 
        // "Einen Schritt weiter gehen"
        kara.move();
    }
    return ergebnis;
  }
</code>
<code>
  '''public void bisZumBaumGehen()'''
  {
    while(!kara.treeFront())
    {
        kara.move();
    }
  }
</code>
<code>
  '''public void blaetterLegen(int anzahl)'''
  {
    for(int i=0; i<anzahl; i++)
    {
        kara.putLeaf();
        kara.move();
    }
  }
</code>
===Programmierung der Hauptmethode===
Jetzt kann man die Hauptmethode programmieren:
Dafür wird die Programmbeschreibung in ein Java-Programm übersetzt.
{| class="wikitable"
! Programmbeschreibung !! Java-Quelltext
|-
|
  {|style="border-style: solid; border-width: 0px;"
    | '''Methode wintervorratAnlegen()'''
    {|style="border-style: solid; border-width: 2px 0px 2px 2px; margin: 5px"
        | ''Es wird die Variable blaetterZahl gebraucht!''<br/>blaetterZahl = blaetterSammeln()<br/>nach rechts drehen<br/>bisZumBaumGehen()<br/>zweimal nach rechts drehen<br/>blaetterLegen(blaetterZahl)
    |}
  |}
|
  '''public void wintervorratAnlegen()'''
  {
    int blaetterZahl = blaetterSammeln();
    kara.turnRight();
    bisZumBaumGehen();
    kara.turnRight();
    kara.turnRight();
    blaetterLegen(blaetterZahl);
   }
   }
|}
|}

Aktuelle Version vom 23. Januar 2022, 16:02 Uhr


Auf dieser Seite werden anhand von Kara grundlegende Programmiertechniken vorgestellt.

Die Grundlagen der Java-Syntax werden auf folgender Seite vorgestellt: Java_Basis-Sprachelemente

Methoden, die n-mal etwas tun

Mit n-mal ist gemeint, dass bekannt ist, wie oft die Wiederholung ausgeführt werden soll.

Dafür braucht man eine Wiederhole n-mal-Schleife. In Java kann man das mit for realisieren.

Beispiel

Kara soll eine Linie von 20 Kleeblättern legen.

Programmbeschreibung Java Quelltext
Methode zwanzigerLinieLegen()
Wiederhole 20-mal
lege ein Blatt
gehe einen Schritt
 public void zwanzigerLinieLegen()
 {
    for(int i=0; i<20; i++)
    {
       kara.putLeaf();
       kara.move();
    }
  }

Methoden, die etwas tun, bis ein Ziel erreicht wird

Solche Methoden brauchen eine Solange-Schleife. In Java kann man das mit while realisieren.

In der Regel haben diese Methoden folgenden Aufbau:

  • Eine Schleife, die so lange läuft, bis das "Ziel" erreicht ist
    In der Schleife passiert folgendes:
    • Es wird "nachgedacht". (Das kann kompliziert sein...)
    • Nach dem Nachdenken: Ein Schritt in Richtung Ziel wird ausgeführt

Wichtig ist dabei, dass in jedem Schleifendurchlauf genau ein Schritt ausgeführt wird, und das erst nach dem "Nachdenken"!

Dadurch wird die Programmierung viel einfacher!

Beispiel

Graph für die Distanzen zwischen Städten

Die folgende Methode lässt Kara rund um einen Wald gehen, bis sie auf einem Blatt steht.

Das "Nachdenken" ist hier relativ kompliziert:
Die größte Schwierigkeit ist für Kara, wenn sie in die "Sackgasse" auf der rechten Seite geht.
Dort muss sie 2x prüfen, ob sie vor einem Baum steht!

Programmbeschreibung Java Quelltext
Methode rundUmDenWald()
Solange Kara nicht auf einem Blatt steht
(Nachdenken!)
wenn kein Baum rechts ist
drehe dich nach rechts
sonst
solange ein Baum vorne ist
drehe dich nach links

(Schritt ausführen!)
gehe einen Schritt
 public void rundUmDenWald()
 {
    while(!kara.onLeaf())
    {
       // (Nachdenken!)
       if(!kara.treeRight())
       {
          kara.turnRight();
       }
       else
       {
          while(kara.treeFront())
          {
             kara.turnLeft();
          }
       }
     
       // (Schritt ausführen!)
       kara.move();
    }
  }

Methoden, die etwas berechnen

Methoden, die etwas berechnen, haben in der Regel folgenden Aufbau:

  • Zuerst wird eine Variable ergebnis deklariert.
  • Dann wird mit einer Schleife das zu berechnende Feld (oder Blätterspur o.ä.) durchlaufen.
    In der Schleife passiert folgendes:
    • Die Berechnung wird aktualisiert
    • Es wird zum nächsten Schritt weitergegangen.
  • Wenn die Schleife fertig ist, dann wird ergebnis zurückgegeben.

Beispiel

Kara zählt Blätter; das Ergebnis ist hier 6.

Die folgende Methode lässt Kara so lange geradeaus laufen, wie Kara auf einem Blatt steht.

Dabei werden die Blätter gezählt und am Ende der Methode zurückgegeben.

Programmbeschreibung Java Quelltext
Methode zaehleBlaetter(): gibt eine Zahl zurück
Setze ergebnis auf 0
Solange Kara auf einem Blatt steht
erhöhe ergebnis um 1
gehe einen Schritt
gib ergebnis zurück;
 public int zaehleBlaetter()
 {
    int ergebnis = 0;
    while(kara.onLeaf())
    {
       ergebnis = ergebnis + 1;
       kara.move();
    }
    return ergebnis;
  }

Zerlegung in mehrere Methoden

Programmieren wird viel einfacher - und vor allem übersichtlicher! - wenn man ein großes Problem in beherrschbare Teilprobleme zerlegt.

Im Idealfall genügt jedes Teilproblem folgenden Anforderungen:

  • Es lässt sich ganz einfach programmieren
  • Es lässt sich einzeln testen

Vorgehensweise

  1. Man überlegt sich, in welche Teilprobleme man das Gesamtproblem zerlegen kann.
  2. Für jedes Teilproblem:
    1. Programmieren
    2. Testen
  3. Jetzt das Gesamtproblem programmieren!

Beispiel 1: Gebirge

Kara soll in einem Tal das Kleeblatt finden

Kara soll über das Gebirge klettern, bis sie in einem Tal ein Kleeblatt findet.

Zerlegung

Man sieht, dass Kara immer abwechselnd bergauf und bergab gehen muss! Daher bietet es sich an, das Gesamtproblem mithilfe der folgenden zwei Methoden zu programmieren:

  • zumGipfel()
  • insTal()

Programmbeschreibung der Hauptmethode

Programmbeschreibung
Methode sucheKleeblatt()
Solange Kara nicht auf einem Blatt steht
zumGipfel()
insTal()

Programmierung der Teilprobleme

Für die Teilprobleme wird hier nur die Programmierung angegeben.


 public void zumGipfel()
 {
    while(kara.treeFront())
    {
        // eine Stufe hochsteigen!
        kara.turnRight();
        kara.move();
        kara.turnLeft();
        kara.move();
    }
 }
  
 public void insTal()
 {
    while(!kara.treeFront())
    {
        // eine Stufe runtersteigen!
        kara.move();
        kara.turnRight();
        kara.move();
        kara.turnLeft();
    }
 }

Programmierung der Hauptmethode

Jetzt kann man die Hauptmethode programmieren, indem man die Methoden zumGipfel() und insTal() verwendet!

Dafür wird die Programmbeschreibung in ein Java-Programm übersetzt.

Programmbeschreibung Java-Quelltext
Methode sucheKleeblatt()
Solange Kara nicht auf einem Blatt steht
zumGipfel()
insTal()
 public void sucheKleeblatt()
 {
    while(!kara.onLeaf())
    {
        zumGipfel();
        insTal();
    }
 }

Beispiel 2: Wintervorrat

vorher
nachher

Kara soll bis zur Höhle gehen und alle Kleeblätter aufsammeln.

Dann soll Kara die gesammelten Kleeblätter in der Höhle ablegen und sich darüber setzen.


Zerlegung

Das Problem besteht aus mehreren Teilproblemen die nacheinander abgearbeitet werden:

  • blaetterSammeln():
    Diese Methode gibt die Zahl der gesammelten Blätter zurück!
    Danach dreht sich Kara nach rechts.
  • bisZumBaumGehen()
    Danach dreht sich Kara zweimal nach rechts.
  • blaetterLegen(int anzahl)
    Dieser Methode wird die Anzahl der gesammelten Blätter übergeben.

Programmbeschreibung der Hauptmethode

Programmbeschreibung
Methode wintervorratAnlegen()
Es wird die Variable blaetterZahl gebraucht!
blaetterZahl = blaetterSammeln()
nach rechts drehen
bisZumBaumGehen()
zweimal nach rechts drehen
blaetterLegen(blaetterZahl)

Programmierung der Teilprobleme

Für die Teilprobleme wird hier nur die Programmierung angegeben.


 public int blaetterSammeln()
 {
    int ergebnis = 0;
    while(kara.treeRight())
    {
        // "Nachdenken"
        if(kara.onLeaf())
        {
            kara.removeLeaf();
            ergebnis = ergebnis + 1;
        }
  
        // "Einen Schritt weiter gehen"
        kara.move();
    }
    return ergebnis;
 }


 public void bisZumBaumGehen()
 {
    while(!kara.treeFront())
    {
        kara.move();
    }
 }


 public void blaetterLegen(int anzahl)
 {
    for(int i=0; i<anzahl; i++)
    {
        kara.putLeaf();
        kara.move();
    }
 }

Programmierung der Hauptmethode

Jetzt kann man die Hauptmethode programmieren:

Dafür wird die Programmbeschreibung in ein Java-Programm übersetzt.

Programmbeschreibung Java-Quelltext
Methode wintervorratAnlegen()
Es wird die Variable blaetterZahl gebraucht!
blaetterZahl = blaetterSammeln()
nach rechts drehen
bisZumBaumGehen()
zweimal nach rechts drehen
blaetterLegen(blaetterZahl)
 public void wintervorratAnlegen()
 {
    int blaetterZahl = blaetterSammeln();
    kara.turnRight();
    bisZumBaumGehen();
    kara.turnRight();
    kara.turnRight();
    blaetterLegen(blaetterZahl);
 }