Frage zum Suchalgorithmus

Lestas89

Bekanntes Mitglied
Ich versuche gerade eine ehemalige Klausuraufgabe zu lösen. Habe jedoch keinen Ansatz, da ich nicht richtig verstehe was gesucht ist.

Die Aufgabe lautet wie folgt:

Die binäre Suche führt die Suche eines Elementes in einem sortierten Array durch. Mit dem Array feld = [3 5 7 8 12] soll die Suche für den Wert 6 manuell durchgeführt werden, indem Sie alle Methodenaufrufe mit ihren Parametern angeben.

Dabei sollen die unterschiedlichen Ebenen eingerückt werden. Sie sollen auch stets m angeben.

Der Quellcode lautet:


Java:
static int binSuche (int[] a, int e, int min, int max) {
 
  if (min > max)
   return -1;
  int m = (min + max) /2;
  if (e == a[m])
   return m;
  if (e < a[m])
   return binSuche (a,e,min,m-1);
  //falls e > a[m]
  return binSuche (a,e,m+1,max);

Ich erwarte auf keinen Fall eine Komplettlösung! Ich will die Aufgabe gerne selber lösen. Ich bräuchte nur einen Ansatz um zu verstehen, was ich machen soll.

Vielen Dank im Voraus :)
 

Lestas89

Bekanntes Mitglied
Hallo MWin123,

danke für den Link. Den habe ich mir schon durchgelesen. Ich weiß aber nicht, wie die Methodenaufrufe aussehen sollen die ich hier aufschreiben muss.
 

Lestas89

Bekanntes Mitglied
Tut mir leid wenn ich das jetzt auch noch frage, aber wie debugge ich (Anfänger)?

Ich glaube selbst das würde mir nicht weiterhelfen. Ich verstehe zwar den Algorithmus, weiß aber nicht, wo ich z.B. die 6 reinschreiben soll im Quellcode für die die Suche durchgeführt werden muss. Kannst du mir da helfen?
 

Lestas89

Bekanntes Mitglied
Muss ich im Quellcode e gleich 6 setzen? Das würde mir schonmal helfen. Hinweis: Das was ich in der Aufgabenstellung feld genannt habe, heißt im Quellcode a
 

InfectedBytes

Top Contributor
vielleicht hilft es dir ja den aller ersten aufruf anzuschauen:
binSuche(a, 6, 0, 4)
a ist das Array
6 ist der gesucht Wert
0 ist der niedrigste Index
4 der höchste Index
 

Lestas89

Bekanntes Mitglied
Hallo InfectedBytes,

tausendmal Danke das du dir Mühe machst. Kannst du mir zeigen, wie du auf den ersten Aufruf gekommen bist? Vielleicht komm ich dann hinter die anderen Aufrufe.
 

InfectedBytes

Top Contributor
du musst halt verstehen was der Algorithmus machen soll.
Die binäre suche erwartet logischerweise als ersten parameter das array.
Der zweite wert (int e) ist der wert der gesucht werden soll, das erkennt man an dieser Zeile:
Java:
if(e == a[m])
   return m;
Danach muss man die grenzen des Arrays angeben, in denen gesucht werden soll.
Zu beginn muss das eben der niedrigste und der höchste index sein (da eben das ganze array durchsucht werden muss)

Der algorithmus ruft sich dann rekursiv selber auf und ändert nur die min/max Index, um die suche einzugrenzen
 

Lestas89

Bekanntes Mitglied
Okay. Ich muss mich da noch ein wenig reindenken. Was mich aber interessiert, wie kamst du denn darauf, dass der Minimalwert 0 und der Maximalwert 4 ist? Das versteh ich nicht. Ich glaube wenn ich dahinter komme, werde ich auch die nächsten Aufrufe verstehen.

Edit: Ach versteh ich das richtig, min und max sind die Arraylängen?
 

InfectedBytes

Top Contributor
du willst das ganze array durchsuchen, also musst du vom ersten bis zum letzten index des arrays gehen.
Der startindex ist logischerweise 0, da Arrays bei index 0 anfangen.
Dein Array besteht aus 5 Elementen, demnach ist der letzte Index 4
 

Lestas89

Bekanntes Mitglied
Wäre der nächste Aufruf dann int binSuche(int[]a,6,0,1) richtig? Ich hoffe ich komme da langsam hinter ...

In der Aufgabenstellung steht auch, dass ich m angeben soll. Welchen Wert hätte m bei diesem Aufruf?
 

Lestas89

Bekanntes Mitglied
Meine nächsten Aufrufe lauten wie folgt:

binSuche(a,6,1,1)
m ist gleich 1

binSuche(a,6,2,1)
return -1

sind die beiden auch richtig? Die Frage ist nur, woher weiß ich wieviele Aufrufe es sind. Wie lange geht das denn?
 

InfectedBytes

Top Contributor
binSuche(a,6,1,1) und m=1 ist korrekt
binSuche(a,6,2,1) ist korrekt, aber m wird nicht berechnet:
Java:
if(min > max)
   return-1;
d.h. es wird -1 zurückgegeben, ohne das m überhaupt berechnet wurde
 

Lestas89

Bekanntes Mitglied
Ich danke dir vielmals für deine Hilfe. Ich nutze diesen Thread mal um nach einem guten Anfängerbuch für Java zu fragen. Könntest du mir da etwas empfehlen, dass ich die Grundlagen sattelfest lernen kann? Womöglich auch einfach erklärt :)
 

InfectedBytes

Top Contributor
in deinem beispielsfall ist es zu ende, da 6 nicht im Array vorhanden ist.
Wenn dein Array allerdings den gesuchten Wert enthalten würde, würde es eben an einer anderen stelle beenden
 


Schreibe deine Antwort... und nutze den </> Button, wenn du Code posten möchtest...
Ähnliche Java Themen
  Titel Forum Antworten Datum
J Frage zum Quellcode - Zusammhänge und Ablauf. Java Basics - Anfänger-Themen 2
D Erste Schritte Frage eines absoluten Anfängers Java Basics - Anfänger-Themen 3
Zrebna Frage zu Test-Driven Development (TDD) Java Basics - Anfänger-Themen 3
I Frage Thymeleaf -> Fehler ignorieren und mit "" ersetzen? Java Basics - Anfänger-Themen 15
I Frage Thymeleaf -> Prefix / Suffix ändern? Java Basics - Anfänger-Themen 11
D Rekursions Probleme / frage Java Basics - Anfänger-Themen 4
T Frage zu Parse Java Basics - Anfänger-Themen 2
H Frage an die Profis Java Basics - Anfänger-Themen 4
J Eine konzeptionelle Frage zu OOP Java Basics - Anfänger-Themen 3
P Frage zu Rekursion und Backtracking Java Basics - Anfänger-Themen 2
H Frage zur Ausgabe Java Basics - Anfänger-Themen 4
H Frage zu arithmetischen Operationen Java Basics - Anfänger-Themen 20
F Kurze Frage zu replace() Java Basics - Anfänger-Themen 19
JavaSchmecktLecker Polymorphie Frage zur Methodenüberschreibung Java Basics - Anfänger-Themen 21
J Frage zu einem "Taschenrechner" code Java Basics - Anfänger-Themen 9
B Erste Schritte Frage zu Instanzierung und Referenzen Java Basics - Anfänger-Themen 8
DoubleM Runtime.getRuntime().exec Frage Java Basics - Anfänger-Themen 2
J Eine theoretische Frage zur Praxis - JPanel oder Canvas Java Basics - Anfänger-Themen 5
O Frage: Formaler Typbezeichner? Java Basics - Anfänger-Themen 3
I BlueJ Queue Frage für Klausur Java Basics - Anfänger-Themen 2
N Verständnis Frage zu Variablen Java Basics - Anfänger-Themen 3
N Spezielle frage zum Comparator Java Basics - Anfänger-Themen 6
L Frage zum Array Java Basics - Anfänger-Themen 1
A Frage zum UML Design Java Basics - Anfänger-Themen 1
I Hilfe bei Klausur Frage Java Basics - Anfänger-Themen 8
izoards Drucken Frage zu FAQ Beitrag Java Basics - Anfänger-Themen 2
J Frage zu meinem Code (OOP) Java Basics - Anfänger-Themen 4
sserio Split() -> Regex Frage. Java Basics - Anfänger-Themen 7
A OCA Study Guide: 2. Frage aus Kapitel 3 Java Basics - Anfänger-Themen 9
sserio Date Library Frage Java Basics - Anfänger-Themen 9
Max246Sch Frage zu Währungsrechner Code Java Basics - Anfänger-Themen 2
sserio Frage zu HashMaps Java Basics - Anfänger-Themen 20
sserio Frage zu Threading - Multithreading Java Basics - Anfänger-Themen 2
sserio Frage zu Lambda Ausdrücken Java Basics - Anfänger-Themen 7
sserio Frage zu BigInteger Java Basics - Anfänger-Themen 1
D Frage bzgl. Enum-Handhabung Java Basics - Anfänger-Themen 16
xxx12 Frage Java Basics - Anfänger-Themen 2
I Generelle Frage zu Mikroservices (Spring Boot?), Docker... Java Basics - Anfänger-Themen 7
R Frage zu Methoden (Rückgabewert u. ohne.) Java Basics - Anfänger-Themen 2
A Frage zur programmierung Java Basics - Anfänger-Themen 12
M Frage zur Methode split der Klasse String Java Basics - Anfänger-Themen 32
R Input/Output Frage zu Java IO Java Basics - Anfänger-Themen 6
M Frage zu printWriter Java Basics - Anfänger-Themen 5
C Frage zu OLSMultipleLinearRegression Java Basics - Anfänger-Themen 31
KogoroMori21 Frage zum Euklidischen Algorithmus Java Basics - Anfänger-Themen 11
S Verständnis-Frage zu einer HÜ? Java Basics - Anfänger-Themen 1
F Frage betreff Programm mit dem man C++-Code in JAVA-Code übersetzen lassen kann Java Basics - Anfänger-Themen 2
L Frage zur Ticket Maschine Java Basics - Anfänger-Themen 1
J Frage zu OOP-Klassendiagramm Java Basics - Anfänger-Themen 8
OSchriever Frage zu Compiler Java Basics - Anfänger-Themen 8
H Frage zu Throw Exception Java Basics - Anfänger-Themen 2
TimoN11 Frage zu Java-Vererbung (Cast) Java Basics - Anfänger-Themen 5
Bademeister007 Hallo Leute ich hab eine Frage zur ArrayList Java Basics - Anfänger-Themen 8
F Frage betreff Programmierbücher zu Lagerverwaltung als Konsolenprogramm Java Basics - Anfänger-Themen 3
dieter000 Kurze Frage kann mir ejmand kurz diesen Code erklären, bzw wie man die zeilen erklärt und so Java Basics - Anfänger-Themen 1
I String.split regex Frage Java Basics - Anfänger-Themen 2
N Best Practice Frage zum MVC-Pattern Java Basics - Anfänger-Themen 2
dieter000 Frage zu einem Beispiel... Java Basics - Anfänger-Themen 5
J Frage zum Loggen Java Basics - Anfänger-Themen 18
J Methoden Frage: Array-Werte in anderer Methode ändern Java Basics - Anfänger-Themen 4
Zrebna Frage zum "Referenzen-konzept" in Java Java Basics - Anfänger-Themen 8
JD_1998 Array-Position aus einer Methode in einer anderen ausgeben (Kurze Frage) Java Basics - Anfänger-Themen 2
marcooooo Frage zu bestimmten Beispiel Java Basics - Anfänger-Themen 31
NeoLexx equals()-Methode Verständnis Frage anhand Code Beispiel Java Basics - Anfänger-Themen 22
N Input/Output Eine Frage über system.out.println. Java Basics - Anfänger-Themen 10
B Erste Schritte Learning Coding (!) Frage an erfahrene Programmierer. Java Basics - Anfänger-Themen 23
M konzeptuelle Frage: In welcher Klasse definiert man am Besten Methoden, die die Kommunikation mit dem User regeln? Java Basics - Anfänger-Themen 8
B Frage zum Code verständnis im Resultat Java Basics - Anfänger-Themen 10
C Exception-Frage Java Basics - Anfänger-Themen 3
J Eine Frage zur Schreibweise == ? : Java Basics - Anfänger-Themen 3
S Frage des Designs Java Basics - Anfänger-Themen 1
JavaTalksToMe Extends/Implements Frage Java Basics - Anfänger-Themen 3
pkm Frage zu Servletfunktion Java Basics - Anfänger-Themen 0
B Frage zur Währungsumrechnung Java Basics - Anfänger-Themen 3
S Allgemeine Frage über Generics und Vererbungen Java Basics - Anfänger-Themen 5
Kirby.exe Frage zur Verwendung von Interfaces Java Basics - Anfänger-Themen 6
D Frage zu Strings einer Exception Java Basics - Anfänger-Themen 4
L Wie frage ich ab, ob in einem Array, Werte doppelt vorkommen? Java Basics - Anfänger-Themen 4
D Frage zur IDE IntelliJ IDEA Java Basics - Anfänger-Themen 6
H Frage zum 2d Array Java Basics - Anfänger-Themen 1
N Frage zum Newton-Fraktal Java Basics - Anfänger-Themen 1
H Frage zu interfaces Java Basics - Anfänger-Themen 1
J Frage dazu Variablen klassenübergreifend zu verändern Java Basics - Anfänger-Themen 22
I Frage zu SkipList Java Basics - Anfänger-Themen 4
G Frage zu JScrollPane Java Basics - Anfänger-Themen 12
Kirby.exe Allgemeine Frage Java Basics - Anfänger-Themen 3
W Frage zu anonymen Klassen Java Basics - Anfänger-Themen 4
J Kleine Frage zu OOP Java Basics - Anfänger-Themen 371
S Frage Klasse und Objekte Java Basics - Anfänger-Themen 2
F Frage zu Iteratoren Java Basics - Anfänger-Themen 2
C Erste Schritte Frage zur ArrayList Java Basics - Anfänger-Themen 15
J Frage zur Vererbung Java Basics - Anfänger-Themen 1
H Frage zur ermittlung eines doppelte Paars aus Sotieralgorithmus Java Basics - Anfänger-Themen 4
H Frage zum Array Java Basics - Anfänger-Themen 17
G Schach -Frage 2- Maussteuerung Java Basics - Anfänger-Themen 7
G Schach in Java - Allgemeine Frage zur Architektur Java Basics - Anfänger-Themen 7
B Fachliche Frage bei Rechnungen Java Basics - Anfänger-Themen 16
B Frage zu: String... strings -> Ungleiche Anzahl an Parameter? Java Basics - Anfänger-Themen 4
B Frage zu Datenbank Design - Rechnungen, Angebote... und deren Positionen Java Basics - Anfänger-Themen 4
H Frage zu Parameter einer Methode Java Basics - Anfänger-Themen 2

Ähnliche Java Themen

Neue Themen


Oben