Verständnisprobleme bei Arrays

juliaa

Mitglied
Hallo zusammen,
ich habe folgenden code, kann aber leider nicht nachvollziehen was das Programm wann macht um auf das Ergebnis zukommen..

Java:
class Klausur {
		
		public static void main (String[] args){
			   
		int []array = new int [] {0,5,1,2,7,4,3,9};
		System.out.println ("MAX: "+arraymax(array,0,array.length-1));
		}
		public static int arraymax (int []array, int untergrenze, int obergrenze){
			if (obergrenze-untergrenze<=1){
				return Math.max (array[obergrenze],array[untergrenze]);
				
			}
	else {
		return Math.max (arraymax(array,untergrenze,(obergrenze+untergrenze)/2),arraymax (array,(obergrenze+untergrenze)/2+1,obergrenze));
	}
		}

}

meine Hauptprobleme
1. Welche bedeutung hat das array.length-1 hier? heißt es das nacheinander von rechts nach links die Zahlen des Arrays in der rekursion als Obergrenze eingesetzt werden??
2. Welche Schritte macht das Programm genau in der if- und else- Bedingung?
Ich möchte gerne das System des Programms verstehen damit ich es auch selber auf andere Beispiele anwenden kann, es wäre super wenn mir jemand helfen könnte.
Gruß
Julia
 

Timothy Truckle

Top Contributor
1. Welche bedeutung hat das array.length-1 hier? heißt es das nacheinander von rechts nach links die Zahlen des Arrays in der rekursion als Obergrenze eingesetzt werden??
Nein.
Die Methode
Code:
arraymax
erwartet gültige Indexe. Die fangen in Java bei 0 an.
Code:
Array.length
gibt dagegen die Anzahl der Elemente an, die beginnt mit 1. In einem Array mit der Länge 3 gibt es also die Indexe 0, 1 und 2 (bitte nachzählen).
Der höchste gültige Index in einem Array ist damit Array.length -1 (weil 3-1=2 ist). Das hat mit der Richtung, in der das Array durchlaufen wird noch n ichts zu tun.

2. Welche Schritte macht das Programm genau in der if- und else- Bedingung?
Das
Code:
if
stellt fest, ob die Indexe in der "richtigen" Reihenfolge übergeben wurden, d.h. ob der erste kleiner als der zweite ist. Wenn das so ist wird der höchste Wert in diesem Abschnitt des Arrays ermittelt.

Wenn nicht wird scheinbar der höchste Wert außerhalb des Abschnittes ermittelt...

bye
TT
 
H

hüteüberhüte

Gast
Hi juliaa,

Java:
    public static void main(String[] args) {
        int[] array = new int[]{0, 5, 1, 2, 7, 4, 3, 9};
        // Array-Deklaration und -Initialisierung

        System.out.println("MAX: " + arraymax(array, 0, array.length - 1));
        // Ausgabe des Aufrufs von arraymax auf der Standardausgabe
        // (und String-Konkatenation)
    }

    /**
     * Rekursive Methode, die mit dem linken und rechten Teilarray
     * erneut aufgerufen wird, und das Maximum bestimmt.
     * 
     * @param array
     * @param untergrenze
     * @param obergrenze
     * @return Maximum des Arrays array zwischen unter- und obergrenze (inklusive)
     */
    public static int arraymax(int[] array, int untergrenze, int obergrenze) {
        if (obergrenze - untergrenze <= 1) {
            return Math.max(array[obergrenze], array[untergrenze]);
        } else {
            return Math.max(
                    arraymax(array, untergrenze, (obergrenze + untergrenze) / 2),
                    arraymax(array, (obergrenze + untergrenze) / 2 + 1, obergrenze) );
        }
    }

meine Hauptprobleme
1. Welche bedeutung hat das array.length-1 hier? heißt es das nacheinander von rechts nach links die Zahlen des Arrays in der rekursion als Obergrenze eingesetzt werden??

Code:
array.length-1
gibt den Index des letzten Array-Elements zurück.

arraymax "halbiert" diesen Bereich und ruft erneut auf, mit dem "linken" und "rechten Bereich".

2. Welche Schritte macht das Programm genau in der if- und else- Bedingung?
Ich möchte gerne das System des Programms verstehen damit ich es auch selber auf andere Beispiele anwenden kann, es wäre super wenn mir jemand helfen könnte.

Sagen wir, ein Array beinhaltet 6 Elemente:

Aufruf 1: 0 bis 5,---Rückgabe max(max(max(array[0], array[1]), max(array[2], array[2])), max(max(array[3], array[4]), max(array[5], array[5])) ),
Aufruf 2: 0 bis 2,--Rückgabe max(max(array[0], array[1]), max(array[2], array[2])),
Aufruf 3: 0 bis 1, Rückgabe max(array[0], array[1]),
Aufruf 4: 2 bis 2, Rückgabe max(array[2], array[2]),
Aufruf 5: 3 bis 5,--Rückgabe max(max(array[3], array[4]), max(array[5], array[5])),
Aufruf 6: 3 bis 4, Rückgabe max(array[3], array[4]),
Aufruf 7: 5 bis 5, Rückgabe max(array[5], array[5]).

Verstehst du jetzt durch dieses Beispiel, wie Rekursion funktioniert?

liebste Grüße LIIII
 
H

hüteüberhüte

Gast
Das ganze hätte man auch etwas einfacher formulieren können:

Java:
    public static int arraymax2(int[] array, int from) {
        if (from == array.length - 1) {
            return array[from];
        }
        return Math.max(array[from], arraymax2(array, from + 1));
    }

Von der Laufzeit her beißt sich da nichts.

Wenn du mehr erfahren möchtest, google mal nach "divide and conquer top down approach". Dann gelangst du z.B. zu so einer schlauen Seite (nicht ironisch gemeint):

Top-Down Algorithms: Divide-and-Conquer

In this section we discuss a top-down algorithmic paradigm called divide and conquer . To solve a given problem, it is subdivided into one or more subproblems each of which is similar to the given problem. Each of the subproblems is solved independently. Finally, the solutions to the subproblems are combined in order to obtain the solution to the original problem.

Divide-and-conquer algorithms are often implemented using recursion. However, not all recursive functions are divide-and-conquer algorithms. Generally, the subproblems solved by a divide-and-conquer algorithm are non-overlapping.

Grüßle
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
L JavaFX - grundlegende Verständnisprobleme Java Basics - Anfänger-Themen 1
D Interface Verständnisprobleme von Interfaces Java Basics - Anfänger-Themen 5
gstarplayer [Verständnisprobleme] Java next(),nextLine,nextInt und parseInt! Java Basics - Anfänger-Themen 22
? Klassen Verständnisprobleme mit Klassen und Metohden Java Basics - Anfänger-Themen 5
? Klassen Verständnisprobleme mit Import Anweisungen Java Basics - Anfänger-Themen 6
J Erste Schritte türme von hanoi verständnisprobleme Java Basics - Anfänger-Themen 6
S Verständnisprobleme wie Java Programme ablaufen Java Basics - Anfänger-Themen 6
K JNI Verständnisprobleme Java Basics - Anfänger-Themen 4
B verständnisprobleme bei Aufgabenstellung Java Basics - Anfänger-Themen 25
M Verständnisprobleme mit Klassennutzung Java Basics - Anfänger-Themen 9
c_sidi90 Hilfe bei GUI Verständnisprobleme Java Basics - Anfänger-Themen 13
A Mal wieder Verständnisprobleme Java Basics - Anfänger-Themen 3
A Code-Verständnisprobleme Java Basics - Anfänger-Themen 10
A Verständnisprobleme eines Lösungscodes Java Basics - Anfänger-Themen 9
B Objektoerientiertes Programmieren, Verständnisprobleme Java Basics - Anfänger-Themen 4
megachucky JDBC-Grundlagen: Verständnisprobleme Java Basics - Anfänger-Themen 31
S Rekursion: Verständnisprobleme Java Basics - Anfänger-Themen 12
M Länge eines Arrays als Variable speichern möglich? Java Basics - Anfänger-Themen 14
R Liste und Arrays Java Basics - Anfänger-Themen 12
N mehrdimensionale arrays Java Basics - Anfänger-Themen 12
E Arrays in einer ArrayList miteinander vergleichen Java Basics - Anfänger-Themen 12
Kingdako Wie löse ich eine Mathematische Formel mit Arrays und Schleifen? Java Basics - Anfänger-Themen 32
D Wie kann man in Java nach Arrays auf Duplikate prüfen Java Basics - Anfänger-Themen 12
S Hilfe bei Praktischen Aufgaben von Arrays Java Basics - Anfänger-Themen 39
T Objekte mit arrays erstellen Java Basics - Anfänger-Themen 6
M Problem bei verschachtelter for-Schleife bei zweidimensionalen Arrays Java Basics - Anfänger-Themen 3
J Mehrdimensionale Arrays Java Basics - Anfänger-Themen 2
pc pc pc pc pc letztes Element eines Arrays n Java Basics - Anfänger-Themen 3
M Arrays Java Basics - Anfänger-Themen 3
Ostkreuz Wert von Arrays summieren Java Basics - Anfänger-Themen 1
Ostkreuz Summieren von Arrays Java Basics - Anfänger-Themen 4
javaBoon86 Arrays 2 Dimension Werte ausgeben Java Basics - Anfänger-Themen 15
paulen1 Best Practice "Unchecked Assignment" Warnung beim erstellen eines 2D Arrays of Arraylists Java Basics - Anfänger-Themen 2
B bei 2 Arrays Anzahl gleicher Elemente vergleichen? Java Basics - Anfänger-Themen 49
JustAProgrammer Ein Dreieck mit Arrays erstellen Java Basics - Anfänger-Themen 2
TheSepp Nur Arrays ausgeben, die Werte zugewiesen haben. Java Basics - Anfänger-Themen 4
volcanos Addition -> List<Integer> mit Arrays.asList() versus List<Integer>ArrayList<>() Java Basics - Anfänger-Themen 14
ArrayList mit unbekannter Menge an Arrays die Arrays vergleichen Java Basics - Anfänger-Themen 9
D Arrays an replaceAll-Methode übergeben Java Basics - Anfänger-Themen 12
rosima26 Geordnete Arrays ausgeben Java Basics - Anfänger-Themen 31
D Inhalt eines Arrays ausgeben Java Basics - Anfänger-Themen 7
A Jedes zweite Element eines Arrays entfernen Java Basics - Anfänger-Themen 30
C Zwei Arrays addieren und ausgeben Java Basics - Anfänger-Themen 3
E Zinsrechnung mithilfe von Arrays Java Basics - Anfänger-Themen 12
LePetitChat1 Arrays - NullPointerException? Java Basics - Anfänger-Themen 14
H Arrays: Größten Zahlen Unterschied herausfinden Java Basics - Anfänger-Themen 20
H Arrays befüllen Java Basics - Anfänger-Themen 43
C60 Methoden Main-Methode erkennt meine Arrays nicht. Java Basics - Anfänger-Themen 7
D Arrays Java Basics - Anfänger-Themen 9
C Java Arrays - Ausgabe in Methode Java Basics - Anfänger-Themen 12
R While-Loop der die Einträge eines Arrays in umgekehrter Reihenfolge anzeigt Java Basics - Anfänger-Themen 3
N Arrays Java Basics - Anfänger-Themen 5
W n verschiedene Arrays zufällig ausgeben - mit der Random-Klasse? Java Basics - Anfänger-Themen 8
U zwei 2D arrays auf gleich sein überprüfen Java Basics - Anfänger-Themen 14
melaniemueller Lagerverwaltung erstellen - mehrdimensionale Arrays Java Basics - Anfänger-Themen 62
C initialisieren eines arrays richtiger Größe und mit geeignetem Datentyp Java Basics - Anfänger-Themen 26
Bademeister007 Elemente aus zwei verschiedenen Arrays miteinander vergleichen und gegeben falls entfernen Java Basics - Anfänger-Themen 14
A Arrays aufsummieren Java Basics - Anfänger-Themen 11
C Wie 2 Arrays zusammenfügen und sortieren? Java Basics - Anfänger-Themen 11
S Arrays aneinanderketten Java Basics - Anfänger-Themen 20
Sinan Arrays auflisten ohne Wiederholung Java Basics - Anfänger-Themen 28
D Hilfe beim Erzeugen eines Arrays NullPointerException wird ausgelöst Java Basics - Anfänger-Themen 11
R Werte und Reihenfolge in 2d Arrays vergleichen Java Basics - Anfänger-Themen 5
D Verschlüsslungsaufgabe / Arrays Java Basics - Anfänger-Themen 6
L Methode für Zweidimensionale Arrays Java Basics - Anfänger-Themen 4
L Methode zum invertieren eines Arrays Java Basics - Anfänger-Themen 7
S zweidimensionale char arrays Java Basics - Anfänger-Themen 14
J Methoden Mehrdimensionale Arrays übereinander legen Java Basics - Anfänger-Themen 5
D Verwirrung bei Streams aus primitiven Arrays Java Basics - Anfänger-Themen 2
P Arrays mit verschiedenen Längen miteinander dividieren. Java Basics - Anfänger-Themen 1
P Wie kann ich die Zahlen dieses Arrays dividieren? Java Basics - Anfänger-Themen 2
N 2D Arrays jedes xy vergleichen Java Basics - Anfänger-Themen 7
J Traveling Salesman Problem [Arrays] Java Basics - Anfänger-Themen 9
M Arrays mit mehreren Werten über JOptionPane initialisieren Java Basics - Anfänger-Themen 12
Kawastori Größe eines Arrays bestimmen Java Basics - Anfänger-Themen 13
Zeppi Arrays[i] Java Basics - Anfänger-Themen 7
Lena_2611 Vergleich von Array1 Index mit Array2 Wert und erzeugen eines neues Arrays Java Basics - Anfänger-Themen 8
J B-Sprache mit Arrays ausführen Java Basics - Anfänger-Themen 18
A Teilarrays eines 2D-Arrays sortieren Java Basics - Anfänger-Themen 4
C Arrays - deklarieren, initialisieren? Ist das ein Objekt? Java Basics - Anfänger-Themen 3
K Sudoku mit 2D Arrays Java Basics - Anfänger-Themen 19
T Vertikales Histogramm mit Arrays Java Basics - Anfänger-Themen 3
JD_1998 Arrays einlesen, zwischenspeichern und wieder ausgeben Java Basics - Anfänger-Themen 8
Z Kein überprüfen des gesamten Arrays möglich.(Viergewinnt Spiel) Java Basics - Anfänger-Themen 6
F Arrays: Mathematische Funktion Java Basics - Anfänger-Themen 19
mihe7 Von Datentypen und (mehrdimensionalen) Arrays Java Basics - Anfänger-Themen 4
A Teilen eines Arrays Java Basics - Anfänger-Themen 5
DorFey Sortieren eines mehrdimensionalen Arrays Java Basics - Anfänger-Themen 8
N Probleme beim printen von Arrays durch for Schleife Java Basics - Anfänger-Themen 3
L If und else bei 2 Dimensionalen Arrays Java Basics - Anfänger-Themen 8
1 Arrays Java Basics - Anfänger-Themen 7
M Rückgabe eines Arrays Java Basics - Anfänger-Themen 10
L Addition von Arrays über die Parameterliste Java Basics - Anfänger-Themen 11
Z Erste Schritte Indexe innerhalb eines Arrays zusammensählen Java Basics - Anfänger-Themen 14
N Länge eines Arrays in einem Objekt testen Java Basics - Anfänger-Themen 51
S Übergabe von Arrays an Methoden Java Basics - Anfänger-Themen 20
D Collections Arrays in ArrayList abspeichern Java Basics - Anfänger-Themen 6
A Freie Stelle eines Arrays Java Basics - Anfänger-Themen 17
H Ein gegebenes Int Array zu Zwei Arrays zurück geben Java Basics - Anfänger-Themen 6
J 2D Arrays summieren Java Basics - Anfänger-Themen 21

Ähnliche Java Themen

Neue Themen


Oben