faecher:informatik:oberstufe:java:algorithmen:arrays:uebungen1:start

Unterschiede

Hier werden die Unterschiede zwischen zwei Versionen der Seite angezeigt.

Link zu der Vergleichsansicht

Beide Seiten, vorherige Überarbeitung Vorherige Überarbeitung
Nächste Überarbeitung
Vorherige Überarbeitung
faecher:informatik:oberstufe:java:algorithmen:arrays:uebungen1:start [05.10.2021 17:40] – [Aufgaben:] sbelfaecher:informatik:oberstufe:java:algorithmen:arrays:uebungen1:start [10.10.2023 13:05] (aktuell) – [Aufgaben:] Frank Schiebel
Zeile 10: Zeile 10:
  
  
-  * **(1)** Erprobe die Methode ''gibGewicht()''. Wie muss sie aufgerufen werden? \\ Klappt der Aufruf immer? \\ Was wird in der Abfrage in Zeile 36 geprüft? Was versucht man hier abzufangen? \\ Erläutere diese Prüfabfrage im Detail. +  * **(1)** Erprobe die Methode ''gibGewicht()''. Wie muss sie aufgerufen werden? \\ Klappt der Aufruf immer? \\ Was wird in der Abfrage in Zeile 31 geprüft? Was versucht man hier abzufangen? \\ Erläutere diese Prüfabfrage im Detail. 
   * **(2)** Vervollständige die Methode ''setzeAn5und9'' zum Setzen eines neuen Wertes für die Elemente ''gewicht[5]'' und ''gewicht[9]'' diesem Array.   * **(2)** Vervollständige die Methode ''setzeAn5und9'' zum Setzen eines neuen Wertes für die Elemente ''gewicht[5]'' und ''gewicht[9]'' diesem Array.
-  * **(3)** Schreibe eine Methode zum Setzen eines neuen Wertes für ein Element dieses Arrays mit wählbarem Index.+  * **(3)** Schreibe eine Methode zum Setzen eines neuen Wertes für ein Element dieses Arrays mit wählbarem Index. Überprüfe dabei, ob der übergebene Index sich im erlaubten Bereich befindet und gib zurück, ob die Operation erfolgreich war.
   * **(4)** Ermittle das  Durchschnittsgewicht der gesamten Messreihe. Notiere zuerst deine Idee und setze sie dann in Quelltext um. Warum sollte dies eine eigenständige Funktion(Methode) werden?       * **(4)** Ermittle das  Durchschnittsgewicht der gesamten Messreihe. Notiere zuerst deine Idee und setze sie dann in Quelltext um. Warum sollte dies eine eigenständige Funktion(Methode) werden?    
   * **(5)** Schreibe eine Methode, die je eine Integer Zahl als Start- (s) und Endindex (e) erhält und damit den Durchschnitt aller Werte mit Indizes (i) zwischen s und e ermittelt.    * **(5)** Schreibe eine Methode, die je eine Integer Zahl als Start- (s) und Endindex (e) erhält und damit den Durchschnitt aller Werte mit Indizes (i) zwischen s und e ermittelt. 
Zeile 18: Zeile 18:
  
 ++++ Lösungsvorschläge  | ++++ Lösungsvorschläge  |
 +Aufgabe 1: Das ist ein klassischer "Getter": ''gibGewicht(index)'' gibt das Gewicht des am Index ''index'' stehenden Arrayelements zurück. Die Überprüfungen sollen sicherstellen, dass man nicht den zulässige Wertebereich für den Index verlässt, als "Fehlermeldung" wird -8.888 zurückgegeben.
  
 Hier ein paar Vorschläge zur Lösung der Aufgaben. Die Methoden können meist noch verbessert werden,  Hier ein paar Vorschläge zur Lösung der Aufgaben. Die Methoden können meist noch verbessert werden, 
Zeile 23: Zeile 24:
  
 <code java> <code java>
-/** +    /**  
-     Aufgabe 3+     Setze ein Element des Arrays auf einen gegebenen Wert. 
 +     * Gib zurück, ob die Operation erfolgreich war.
            
-     * @param  index Index des zu setzenden Elements +     *  
-     * @param  value    Wert, auf den das Element gesetz werden soll  +     * @param index Index des zu setzenden Elements 
 +     * @param wert Wert, der an diesem Index gesetzt werden soll 
 +     * @return boolean Erfolgreich oder nicht
      */      */
-    public void insertAtIndex(int index, double value) +    public boolean setzeAnIndex(int index, double wert) { 
-    +         
-        gewicht[index] = value// das geht natürlich auch besser...+        if(index < 0 || index > anzahl) return false; 
 +         
 +        gewicht[index] = wert; 
 +        return true
     }     }
- 
     /**     /**
      * Aufgabe 4       * Aufgabe 4 
Zeile 70: Zeile 76:
  
 ++++ ++++
-++++ Ohne BlueJ |  
-<code java App.java> 
-/** Fachklasse: Messreihe  (=eine Reihe von nummerierten Messdaten) 
-  @author: thh 
-  @author: fs 
-  @version: 20200115 
- */ 
  
-public class Messreihe { 
-    // Objektvariablen deklarieren 
-    int anzahl = 45; 
-    double[] gewicht = new double[anzahl]; 
- 
-    /** Konstruktor fuer Objekte der Klasse Messreihe 
-      Jede Messreihe enthaelt eine Reihe von positiven Messdaten (Gewichten); 
-     */ 
-    public Messreihe() { 
-        for (int i=0; i<anzahl; i++) {    // Alle Gewichte  
-            gewicht[i] = erzeugeZZahl();  // der Reihe nach festlegen 
-        } 
-    } 
- 
-    /** das Element der Reihung mit dem Index i zurueckgeben 
-      Der gewuenschte Index i muss eingegeben werden 
-      Bei Eingabe eines nicht vorhandenen Index wird  
-      -8.888 als Fehlersignal zurueckgemeldet   */ 
-    public double gibGewicht(int i)   { 
-        if (i<0 || i>anzahl) {              //<-- 2. 
-            return -8.888;       // als Fehlersignal!   
-        } 
-        else { 
-            return gewicht[i];  
-        } 
-    }  
-     
-    /** setzt fuer zwei Elemente der Messreihe neue Werte fest. 
-      Das Element mit dem Index 5 in Reihung gewicht[ ] wird auf 555.55 gesetzt 
-      Das Element mit Index 9  auf den Wert 99.99    */ 
-    public void setzeAn5und9() {   
-        // deine Aufgabe            //<-- 3.a) b) 
-    }     
-   
- 
-    /*# <-- 4. Aufgabe */ 
-     
-     
-    // ----------- Hilfsfunktionen 
-    /** dient zum Anzeigen der Reihung am Bildschirm; 
-      kann durch GUI oder INSPECT ersetzt werden */ 
-    public void anzeigen() { 
-       System.out.println("\n   Aktuelle Messreihe:");  
-        for (int i=0; i< anzahl; i++) { 
-            schreibe(i, gewicht[i]);  
-       } 
-    }     
-         
-    //------ interne Hilfsfunktionen 
-    /** interne Methode, um eine Zufallszahl im Bereich 200.0 - 799.999 
-      mit 3 Nachkommastellen zu erzeugen;  
-      Math.random() liefert eine Zahl von 0 (inkl.) bis 1 (exkl.)  */ 
-    private double erzeugeZZahl()   { 
-        double zufZahl = 200 + 600*Math.random(); 
-        return Math.round((zufZahl*1000))/1000.0; 
-    } 
-     
-    /** interne Hilfsfunktion zur Anzeige;  
-      setzt ein- bis zweistelligen Zahlen stellenrichtig ein. */ 
-    private void schreibe(int i, double wert) { 
-        String erg = "Index"; 
-        if (i<10) {  
-            erg = "Index  " + i;   // Zwei Leerzeichen drin !! 
-        } 
-        else  {  
-            erg = "Index " + i;    // hier nur eines !! 
-        } 
-        System.out.println(erg+" :  "+wert);  
-    } 
-} 
- 
-/* App Klasse: Steuert den Programmablauf */ 
-public class App { 
-    
-    public static void main(String[] args)  
- { 
- Messreihe reihe1 = new Messreihe(); 
-                reihe1.anzeigen(); 
-                // Erzeuge eine zweite Messreihe reihe2 und gebe sie aus 
-       
-                // Teste weitere Methoden/bearbeite die Aufgaben unten/im Wiki 
-                double g=reihe1.gibGewicht(20); 
-                System.out.println("Gewicht " + g); 
- } 
-     
-} 
- 
-/** Aufgaben: 
-     
- * 1. Erprobe die Methode gibGewicht(). Wie muss sie aufgerufen werden. 
-    Klappt der Aufruf immer? 
-    Was wird in der Abfrage Z.28 geprueft? Was versucht man hier abzufangen?  
-    Erlaeutere diese Pruefabfrage im Detail.  
-    
- * 2.a) Vervollstaendige diese Methode zum Setzen eines neuen Wertes fuer 
-    die Elemente gewicht[5] und gewicht[9] dieser Reihung. 
-   b) Schreibe eine Methode zum Setzen eines neuen Wertes fuer ein  
-    Element dieser Reihung mit waehlbarem Index. 
-   c) Teste deine Methoden mit entsprechenden Anweisungen in main() 
-     
-  
- * 3. Ermittle das  Durchschnittsgewicht der gesamten Messreihe.  
-    Notiere zuerst deine Idee und setze sie in Quelltext um.  
-    Warum sollte dies eine eigenständige Funktion(Methode) werden?     
-  
- * 4. Schreibe eine Methode, die je eine Interger Zahl als Start- (s) und Endindex  (e) erhält  
-    und damit den Durchschnitt aller Werte mit Indizes (i) zwischen s und e ermittelt.  
-        
- */ 
-</code> 
- 
-++++ 
  
  • faecher/informatik/oberstufe/java/algorithmen/arrays/uebungen1/start.1633455650.txt.gz
  • Zuletzt geändert: 05.10.2021 17:40
  • von sbel