Array, lineare Suche, binäre Suche, Programm bleibt unerwartet stehen...

Neo Larson

Mitglied
Guten Abend,

ich habe ein Programm geschrieben, welches:

1. die Slot-Anzahl für ein Array bekommt
2. ein eigenes Objekt vom Typ IntArray erzeugt und die Anzahl an den Konstruktor des IntArray-Objekts weitergibt
3. der Konstruktor startet eine Methode zur Eingabe der Array-Werte, anschließend werden diese ausgegeben
4. der Konstruktor startet eine Methode, die die Werte aufsteigend ordnet, anschließend wieder Ausgabe

5. die main-Methode fragt nach der zu suchenden Zahl
6. in der main wird die lineare Suche gestartet und der gefundene Slot zurückgegeben
Falls ja, wird eine rekursive binäre Suche anschließend eine iterative binäre Suche gestartet
Falls nein, wird "Element nicht gefunden" ausgegeben.
7. die main fragt nach einer weiteren Suche
Falls ja, gehts bei 5. weiter
Falls nein, wird das Programm beendet


Nun zu meinem Problem:

Das Programm bleibt nach mehrmaligem Suchdurchlauf bei Punkt 6 nach der rekursiven binären Suche stehen.

Die Klasse IntArray, die mit der main getestet wird.

Java:
import java.util.Scanner;                            // Scanner-Klasse wird fuer die Eingabe benoetigt

class IntArray
{
    // Instanzvariable
    int[] array;

    // Konstruktor
    IntArray(int index)
    {
        array = new int[index];

        werteRein();
        printArray();
        ordnenArray();
        printArray();
    }

    // Methoden

    /* Die Methode werteRein() wird vom Konstruktor verwendet, um 
       das Array zu befuellen */
    void werteRein()
    {
        Scanner scan = new Scanner(System.in);

        for(int slot=0; slot<array.length; slot++)
         {
            System.out.print("Den " +(slot+1)+ ". Wert eingeben: ");
            array[slot]=scan.nextInt();
        }
    }

    /* Die Methode ordnenArray() wird vom Konstruktor verwendet, um
       das gefuellte Array aufsteigend zu sortieren */
    void ordnenArray()
    {
        int temp, min;
        int slot3=0;

        System.out.println("\nDie Zahlen werden geordnet!");

        for(int slot1=0; slot1<array.length; slot1++)
         {
            temp=array[slot1];
            min=array[slot1];

            for(int slot2=slot1; slot2<array.length; slot2++)
             {
                if(array[slot2]<min)
                {
                    min=array[slot2];
                    slot3=slot2;
                }

            }
            array[slot1]=min;
            if(min!=temp)
                array[slot3]=temp;
        }
    }

    /* Die Methode linSuche() sucht innerhalb des Arrays nacheinander
       alle Elemente nach dem zu suchenden Element ab */
    int linSuche(int ziel)
    {
        for(int slot=0; slot<array.length; slot++)
         {
            Integer arraySlot = new Integer(array[slot]);
            if(arraySlot!= null )
                if(ziel==array[slot])
                    return slot;
        }
        return -1;
    }

    /* Die Methode binSuche() sucht innerhalb des Arrays
       mithilfe einer rekursiven binaeren Suche nach dem zu suchenden
       Element */
    int binSuche(int start, int ende, int ziel)
    {
        int mittel = (start + ende)/2;

        if(array[mittel]==ziel)
            return mittel;

        if(start==ende)
            return -1;

        if(array[mittel]>ziel)
            return binSuche(start, mittel-1, ziel);

        return binSuche(mittel+1, ende, ziel);
    }

    /* Die Methode binSuche() sucht innerhalb des Arrays
       mithilfe einer iterativen binaeren Suche nach dem zu suchenden
       Element */
    int binSucheIter(int start, int ende, int ziel)
    {
        int mittel=(start+ende)/2;

        while(array[mittel]!=ziel)
        {
            mittel=(start+ende)/2;

            if(start==ende)
                return -1;

            if(array[mittel]>ziel)
                mittel-=1;

            start=mittel;
        }

        return mittel;
    }

    /* Die Methode printArray() gibt alle Array-Elemente
       vor und nach dem Ordnen auf dem Bildschirm aus */
    void printArray()
    {
        System.out.println();

        for(int slot=0; slot<array.length; slot++)
         {
            System.out.print(array[slot]);

            if(slot<(array.length-1))
                System.out.print(", ");
        }
        System.out.println();
    }
}

Die main-Methode

Java:
public class TestLinSuche
{
    public static void main(String[] args)
    {
        Scanner scan = new Scanner(System.in);

        int anzahl, gesucht, gefunden;
        int suche=1;

        System.out.print("\nWie viele Slots soll das Array bekommen: ");
        anzahl=scan.nextInt();

        IntArray arr1 = new IntArray(anzahl);

        while(suche == 1)
        {
            System.out.println("\nNach welcher Zahl möchten Sie suchen: ");
            gesucht=scan.nextInt();

            gefunden=arr1.linSuche(gesucht);

            if(gefunden >= 0)
            {
                System.out.println("\nDie Zahl ist auf Slot " +gefunden);
                System.out.println("\nRekursive binaere Suche: " +arr1.binSuche(0, anzahl-1, gesucht));
                System.out.println("Iterative binaere Suche: " +arr1.binSucheIter(0, anzahl-1, gesucht));
            
            }
            else
                System.out.println("\nElement nicht gefunden!");

            System.out.println("\nMöchten Sie eine weitere Zahl suchen?\nJa: 1\nNein: 0");
            suche=scan.nextInt();

            while(suche!=1)
            {
                if(suche!=0)
                {
                    System.out.println("Nur zwischen 1 und 0 waehlen.");
                    suche=scan.nextInt();
                }
                else
                    System.exit(0);
            }
        }
    }
}

Kann mir eventuell einer sagen, ob ich was übersehen und/oder was falsch hab?

Vielen Dank
Neo</array.length;></array.length;></min)
</array.length;></array.length;></array.length;>
 
Zuletzt bearbeitet:

VfL_Freak

Top Contributor
Moin,

außerdem: was bedeutet "das Programm bleibt stehen" ??
Da kommt doch sicher in der Konsole ein Fehler!
Poste den StackTrace !!

Gruß Klaus
 

Neo Larson

Mitglied
Nee, kommt kein Fehler.
Das Programm läuft, hab drei von 8 Zahlen getestet (1, 2, 6, ...)
Beim dritten Durchlauf (bei der 6) bleibt das Programm einfach stehen.

Quasi zwischen beiden Bildschirmausgaben, während das Programm läuft:
System.out.println("\nRekursive binaere Suche: " +arr1.binSuche(0, anzahl-1, gesucht));


System.out.println("Iterative binaere Suche: " +arr1.binSucheIter(0, anzahl-1, gesucht));

Da kommt nichts. Als ob es abstürzt...
 

Joose

Top Contributor
Beim dritten Durchlauf (bei der 6) bleibt das Programm einfach stehen.

Nein es bleibt nicht stehen, sondern es läuft weiter und arbeitet deinen programmierten Code ab!
Das Problem liegt daran das deine Logik falsch ist. Gib am Anfang der Methode "binSuche" eine Konsolen-/Logmeldung aus.
Du wirst sehen das dein Programm einfach die Methode "binSuche" abarbeitet dabei sich aber wahrscheinlich in eine "Endlosrekursion" verrennt.
 

Neo Larson

Mitglied
Habe den Code geändert und er funktioniert nun

Java:
    int binSucheIter(int start, int ende, int ziel)
    {
        int mittel;

        while(ende >= start)                        // Solange das Array-Ende groeßer oder gleich dem Array-Start
        {
            mittel=(start+ende)/2;                    // Berechnet den Mittelwert

            if(ziel < array[mittel])                // Das Ziel-Element ist auf der linken Seite, suche dort weiter
                ende=mittel-1;
            else                            // Das Ziel-Element ist auf der rechten Seite, suche dort weiter
                start=mittel+1;
             if(ziel == array[mittel])                // Das Ziel-Element entspricht dem Mittelwert
                return mittel;                    // und der passende Slot wird zurueckgegeben
        }
        return -1;                            // Das Ziel-Element wurde nicht gefunden
    }

Vielen Dank für Eure Unterstützung
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
P Lineare Suche im Array Java Basics - Anfänger-Themen 5
U Lineare Suche in einem Array Java Basics - Anfänger-Themen 3
G Array - lineare Liste Java Basics - Anfänger-Themen 2
T Array verkleinern Java Basics - Anfänger-Themen 2
J Array aus Numberfield Eingaben Java Basics - Anfänger-Themen 7
D Array List mit Objekten sortieren Java Basics - Anfänger-Themen 2
onlyxlia Anzahl Random Zahlen mit Scanner abfragen und in Array speichern Java Basics - Anfänger-Themen 10
Ü Java Array - Buchstaben als Zahlen ausgeben Java Basics - Anfänger-Themen 22
Ü Zweidimensionales Array in der ersten Zeile deklarieren Java Basics - Anfänger-Themen 13
Thomas Uppe 2D Array Reihenfolge vermischen Java Basics - Anfänger-Themen 4
T array auslesen Java Basics - Anfänger-Themen 2
Nitrogames Variablen Variable aus JOptionPane Abfrage in Array einfügen Java Basics - Anfänger-Themen 4
moini Auf Array aus Superklasse zugreifen? Java Basics - Anfänger-Themen 2
J ArrayList in 2D-Array konvertieren. Java Basics - Anfänger-Themen 48
M NullPointerException: Cannot read the array length because "this.Kinder" is null Java Basics - Anfänger-Themen 1
P Wieso kann ich als Index für einen Array einen Char angeben? Java Basics - Anfänger-Themen 3
Finn_lol Fehlermeldung bei Schleife mit Array Java Basics - Anfänger-Themen 4
Proxy Chars vor array übergabe toLowerUpcase Java Basics - Anfänger-Themen 14
iAmFaiinez Primzahlen Tester ohne Array Java Basics - Anfänger-Themen 4
S array 2 dimensional treppe Java Basics - Anfänger-Themen 3
S Array 2x2 Blöcke mit 0 und 1 Java Basics - Anfänger-Themen 10
C Array von Klassen Java Basics - Anfänger-Themen 2
julian0507 2Dim-Array Spaltensummen Java Basics - Anfänger-Themen 1
XWing Doppelte Zahlen im Array Java Basics - Anfänger-Themen 8
melisax Java 2D-Array Tabelle Java Basics - Anfänger-Themen 4
melisax Java Array Wert an bestimmtem Index angeben Java Basics - Anfänger-Themen 14
W Items löschen aus String Array vom Custom Base Adapter Java Basics - Anfänger-Themen 2
Proxy Stack erweitern mit neuem Array falls der alte voll ist!? Java Basics - Anfänger-Themen 5
E Array, nächste Zahl zur 5 ausgeben, wie? Java Basics - Anfänger-Themen 42
J Array.list vergleichen Java Basics - Anfänger-Themen 1
W Java-Code mit Array Java Basics - Anfänger-Themen 14
D Reflections & Generisches Array Java Basics - Anfänger-Themen 4
T Array Java Basics - Anfänger-Themen 2
T Array Java Basics - Anfänger-Themen 15
T Wörteranzahl im Array zählen Java Basics - Anfänger-Themen 9
Ostkreuz Zweidimensionaler Array Index Java Basics - Anfänger-Themen 2
S String Array Buchstaben um einen gewissen Wert verschieben Java Basics - Anfänger-Themen 4
R Images aus einem Array ausgeben Java Basics - Anfänger-Themen 3
R 2d Array individuell machen Java Basics - Anfänger-Themen 4
D 2D Char Array into String Java Basics - Anfänger-Themen 2
J Array Median bestimmen Java Basics - Anfänger-Themen 6
S Array Maximum bestimmen mit for und foreach Java Basics - Anfänger-Themen 7
S Prüfen ob ein zweidimensionales Array rechteckig ist Java Basics - Anfänger-Themen 4
N Array Java Basics - Anfänger-Themen 1
J Array Mittleren Wert bestimmen Java Basics - Anfänger-Themen 2
D OOP Array einem Objekt zuweisen Java Basics - Anfänger-Themen 2
O Zahlen aus einem char-array per char + Zeichen addieren Java Basics - Anfänger-Themen 2
S leeres Array statt Null Pointer Exception ausgeben Java Basics - Anfänger-Themen 20
S Inhalte aus Array vergleichen und Max ausgeben Java Basics - Anfänger-Themen 3
M 2d array ohne längen anlegen Java Basics - Anfänger-Themen 4
S Bestimmte werte aus einem Array löschen Java Basics - Anfänger-Themen 2
S Ausgeben wie oft ein Wert in einem Array vorkommt Java Basics - Anfänger-Themen 7
E Reihenfolge der Werte umdrehen (mittels statischem int-Array Java Basics - Anfänger-Themen 3
O 2 Dimensionales Array Java Basics - Anfänger-Themen 6
M Bubble Sort - Int[] Array sortieren Java Basics - Anfänger-Themen 2
javaBoon86 Array mehrere Dimensionen Java Basics - Anfänger-Themen 10
B Array nach Elementwerten sortieren? Java Basics - Anfänger-Themen 1
B Explizit Array definieren geht nicht? Java Basics - Anfänger-Themen 14
D Kleinste Zahl in Array finden die vorher noch errechnet werden müssen. Java Basics - Anfänger-Themen 4
L Gegebenes Array sortieren, indem zufällige Zahlenpaare aus Array ausgewählt werden Java Basics - Anfänger-Themen 14
Say 2-DIM Array Code lesen und verstehen Java Basics - Anfänger-Themen 5
N Array beim erstellen mit Werten füllen Java Basics - Anfänger-Themen 6
C Java Array Struktur, welche ist wann besser? Java Basics - Anfänger-Themen 12
Temsky34 Array IndexOf nicht verfügbar Java Basics - Anfänger-Themen 18
belana wie am besten 2D Array von String to Integer Java Basics - Anfänger-Themen 18
S Array mit Methode löschen Java Basics - Anfänger-Themen 2
J Java To String Methode, Array mit For-Schleife Java Basics - Anfänger-Themen 2
E Durch Muster in Array iterieren Java Basics - Anfänger-Themen 3
L Frage zum Array Java Basics - Anfänger-Themen 1
C 2D Array Ausgabe mit for-Schleife i,j Java Basics - Anfänger-Themen 4
D Methode: Array Reihenfolge tauschen Java Basics - Anfänger-Themen 3
julian0507 Array aus Methode in anderer Methode sichtbar machen Java Basics - Anfänger-Themen 10
P Array vom Typ Klasse Java Basics - Anfänger-Themen 18
Lion.King Array deklarieren und initialisieren Java Basics - Anfänger-Themen 5
P Array-Objekte-Aufruf Java Basics - Anfänger-Themen 22
A CSv.Datei einlesen und die werte in zweidemosional Int Array speichern Java Basics - Anfänger-Themen 9
M Methoden Zweidimensionaler Array mit Setter Methode ändern Java Basics - Anfänger-Themen 4
AkiJou Zeile in 2d Array löschen Java Basics - Anfänger-Themen 2
LilliCherry Array in einer Zeile ausgeben Java Basics - Anfänger-Themen 6
A Elemente in einem Array Java Basics - Anfänger-Themen 5
A Vorkommende Farben ermittel und als Array zurückgeben Java Basics - Anfänger-Themen 7
AhmadSlack Array Java Basics - Anfänger-Themen 7
Jambolo Kartenhand Array Java Basics - Anfänger-Themen 14
ravenz Schleife mit for über String Array „zahlen“und prüfen ob Wert „a“ oder „b“ oder „c“ entspricht (mittels || ) Java Basics - Anfänger-Themen 4
S Eine Variable in einem Array speichern Java Basics - Anfänger-Themen 5
T Methode, die prüft ob in einem Int-Array maximal 2 Zahlen enthalten sind, die größer als ihr Vorgänger sind Java Basics - Anfänger-Themen 5
T String Array Fehler beim Index Java Basics - Anfänger-Themen 3
krgewb byte-Array, das ein Bild repräsentiert Java Basics - Anfänger-Themen 1
1 Array rekursiv durchlaufen Java Basics - Anfänger-Themen 8
I Methoden Wieso wird mein Array "a" verändert und meine Variable "a" nicht? Java Basics - Anfänger-Themen 4
EykS 3D Druckdatei basierend auf 3D Array? Java Basics - Anfänger-Themen 3
sserio Array funktioniert nicht Java Basics - Anfänger-Themen 2
sserio Iterierung über ein zweidimensionales Array Java Basics - Anfänger-Themen 16
sserio Zweidimensionales Array [][] wird untereinander ausgegeben Java Basics - Anfänger-Themen 14
Chris.089 2 Werte im Array tauschen Java Basics - Anfänger-Themen 6
D EinMalEins mithilfe einer for-Schleife und Array Java Basics - Anfänger-Themen 1
L Unbekanntes Problem mit 2d Array Java Basics - Anfänger-Themen 6
L Gridmuster in einem Array Java Basics - Anfänger-Themen 2
sgtcoopa Array übergeben Schleife Java Basics - Anfänger-Themen 0
B Compiler-Fehler Array aus Objekten übergeben Java Basics - Anfänger-Themen 7

Ähnliche Java Themen

Neue Themen


Oben