Nachbau der indexOf Methode

Status
Nicht offen für weitere Antworten.

ska3k

Aktives Mitglied
Hallo,
ich hab hier mal versucht, die indexOf Nachzuprogrammieren, doch er liefert mir ständig nur den Wert -1, also nix gefunden, zurück. Wenn er etwas findet, dann soll er mir die Position des ersten Zeichens vom Suchstring zurückgeben. Wenn das wort mehrmals im Szring ist, soll er nur den ersten Fundort zurückgeben.

Vielleicht kann mir einer von euch sagen, wo der Fehler bei mir genau liegt:


Code:
  private static String b_index(String s) {
    String ein;
    int check,count=0,pos=-1,n;
    
    System.out.print("Suchstring im anderen: ");
    ein=Eingabe.readString();
    

//    if (s.indexOf(ein)!=-1) {
//      return String.valueOf(s.indexOf(ein)+1);
//    } else {
//      return String.valueOf(s.indexOf(ein));
//    }

    for (int i=0; i<=s.length()-1; i++) {

      if (s.charAt(i)==ein.charAt(0)) {
        check=i;

        for (n=1; n<=ein.length()-2 && (s.length()-ein.length())>=0; n++,check++) {
          if (s.charAt(check)==ein.charAt(n)) {
            count++;
          }
        }
        
        if (count==ein.length() && pos==-1) {
          pos=i;
        }
        
        if (count!=ein.length()) {
          count=0;
          n=1;
        }
      }
    }

//    if (count==ein.length()) {
//      pos=count;
//    }
    
    return String.valueOf(pos);

  }
 

André Uhres

Top Contributor
ska3k hat gesagt.:
Nachbau der indexOf Methode
Code:
static int indexOf(String source, String target, int fromIndex) {
    if (fromIndex >= source.length()) {
        return (target.length() == 0 ? source.length() : -1);
    }
    if (fromIndex < 0) {
        fromIndex = 0;
    }
    if (target.length() == 0) {
        return fromIndex;
    }
    char first  = target.charAt(0);
    int max = source.length() - target.length();
    for (int i = fromIndex; i <= max; i++) {
        if (source.charAt(i) != first) {
            while (++i <= max && source.charAt(i) != first){}
        }
        if (i <= max) {
            int j = i + 1;
            int end = j + target.length() - 1;
            for (int k = 1; j < end && source.charAt(j) == target.charAt(k); j++, k++){}
            if (j == end) {
                return i;
            }
        }
    }
    return -1;
}
 

diggaa1984

Top Contributor
Code:
for (int i=0; i<=s.length()-1; i++) { 

      if (s.charAt(i)==ein.charAt(0)) { 
        check=i; 

        for (n=1; n<=ein.length()-2 && (s.length()-ein.length())>=0; n++,check++) { 
          if (s.charAt(check)==ein.charAt(n)) { 
            count++; 
          } 
        } 
        
        if (count==ein.length() && pos==-1) { 
          pos=i; 
        } 
        
       if (count!=ein.length()) { 
          count=0; 
          n=1; 
        }
      } 
    }
was hamwa hier:

Beispiel:
s = "Wenn Fliegen hinter Fliegen fliegen, fliegen Fliegen Fliegen nach"
ein = "Fliegen"

(braucht nen substring der minimum 2x drin is :D )

so: check 0 ... count 0 ... pos -1 .. schleife rennt los

du suchst nun den ersten Buchstaben aus ein in s ... findest den am am index 5 und speicherst das in check (check = 5, i = 5) ... weiter gehts in der andern schleife

nun schaust du ob in s auch die richtigen Buchstaben aus ein folgen.

1. Schleifendurchlauf:
n = 1 ... check = 5 (das check++ in der schleifenbeschreibung wirkt erst nach 1. Durchlauf) daher nun folgendes ... die if-Bedingung prüft nun den Buchstaben "F" in s (da check++ nocht nich gewirkt hat und check somit immer noch 5 ist = Anfangsbuchstabe von ein) mit dem 2. Buchstaben in ein = "l" ... kann schonma nicht klappen. Weiterhin kannst du diese Schleife sofort abbrechen, wenn die Bedingung nicht gilt. Spart Laufzeit.

Solltest du das Wort dann doch mal gefunden werden, nach entsprechenden Umbaumaßnahmen, so kannst du, wenn du pos = i setzt auch gleich return pos ranhängen und die Suchen abbrechen.

Ich will nun nicht behaupten, dass das des Rätsels Lösung ist, dennoch ein Anfang um dein Problem in Griff zu bekommen. Hatte nich soviel Zeit das genauer durchzuspinnen.
 

Saxony

Top Contributor
Hiho,

kann man das nich auch relativ kompakt à la:

Code:
private static int myIndexOf(String aSource, String aFind) {
		
		if (aFind.length() > aSource.length()) return -1;
		
		char[] source = aSource.toCharArray();
		char find = aFind.charAt(0);
		
		int border = source.length - aFind.length();
		
		for(int i = 0; i <= border; i++) {
			
			if (source[i] == find) {
				
				String s = aSource.substring(i, i + aFind.length());
				
				if (s.equals(aFind)) return i;
			}
		}
		
		return -1;		
	}

schreiben!?

bye Saxony
 

ska3k

Aktives Mitglied
Das wäre eine Lösung des Problems ;)

Das Prolem ist aber, dass ich nur die charAt und length Methode verwenden will. Mit der substring ist es natürlich leicht zu realisieren.
 

ska3k

Aktives Mitglied
Auch, wenn der String im source string drin ist, bringt er nicht gefunden, als -1.

Code:
  private static String b_index(String source, String target) {
    int check,count=0,pos=-1,n;


    for (int i=0; i<=source.length()-1; i++) {

      if (source.charAt(i)==target.charAt(0)) {
        check=i;
        check++;
        
        for (n=1; n<=target.length()-2 && (source.length()-target.length())>=0; n++,check++) {
          if (source.charAt(check)==target.charAt(n)) {
            count++;
          } else {
            break;
          }
        }

        if (count==target.length()) {
          return String.valueOf(i);
        }

        if (count!=target.length()) {
          count=0;
          n=1;
        }
      }
    }

    return String.valueOf(-1);

  }


Hab mich an deinen Änderungen gehalten, vlt findest du noch den restlichen Fehler ;)
 

diggaa1984

Top Contributor
hm mach mal in der 2. schleife bis <= target.length() -1 ... weil mit -2 läuft die schleife nie solange, das count jemals der länge des wortes entsprechen könnte, weiterhin ist count bereits mit gefundenem index i auf 1 zu setzen
 

ska3k

Aktives Mitglied
Code:
    for (int i=0; i<=source.length()-1; i++) {

      if (source.charAt(i)==target.charAt(0)) {
        check=i;
        check++;
        
        for (n=1; n<=target.length()-1 && (source.length()-target.length())>=0; n++,check++) {
          if (source.charAt(check)==target.charAt(n)) {
            count++;
          } else {
            break;
          }
        }

        if (count==target.length()) {
          return String.valueOf(i);
        }

        if (count!=target.length()) {
          count=1;
          n=1;
        }
      }
    }


Klappt auch nicht
 

diggaa1984

Top Contributor
dann lass dir ausgeben was in der 2. forschleife jeweils getestet wird und wie die count und check-werte liegen etc.
musst den fehler ja auch in der ausgaben finden können
 

Saxony

Top Contributor
Hiho,

also komplett straight forward kommt soetwas bei mir raus:

Code:
private static int b_index(String source, String target) {

	for (int i = 0, n = 1, sL = source.length(), tL = target.length(); i <= sL - tL; i++, n = 1) {

		if (source.charAt(i) == target.charAt(0)) {

			for (int j = 1; j < tL; j++) {

				if (source.charAt(i + j) == target.charAt(j)) n++;
				else break;
			}
			if (n == tL) return i;
		}
	}
	return -1;
}

KA für was du den ganzen Variablendschungel brauchst! ;)

[edit]
Wenn man n immer gleich auf 1 setzt, kann man in der inneren Schleife noch eine Iteration, eine Addition, zwei charAts, einen Vergleich, ein Inkrement von j und wenn ja noch ein Inkrement von n sparen. :D
[/edit]

bye Saxony
 

André Uhres

Top Contributor
Der Code von Saxony ähnelt meinem Beispiel, aber in diesem Fall krieg ich eine Exception:
Code:
String find = "";
...
int index = b_index("acb", find);
StringIndexOutOfBoundsException: String index out of range: 0
Gruß,
André
 

diggaa1984

Top Contributor
muss aber schon sagen, das ich den ersten for-schleifen-kopf von Saxony nicht wirklich appetitlich finde ^^ .. nur weil mans in eine zeile schreiben kann, heisst es ja nich das es sich besser liest ^^
 

Saxony

Top Contributor
Hiho,

ich sagte ja straight forward - also so tippen wie ich dachte das es funktioniert.

Mit Sicherheitsüberprüfung und Variablenaufdrösselung:

Code:
private static int b_index(String source, String target) {

	if ((source == null) || (target == null)) return -1;

	final int sL = source.length();
	final int tL = target.length();

	if ((tL == 0) || (tL > sL)) return -1;

	for (int i = 0, n = 1; i <= sL - tL; i++, n = 1) {

		if (source.charAt(i) == target.charAt(0)) {

			for (int j = 1; j < tL; j++) {

				if (source.charAt(i + j) == target.charAt(j))
					n++;
				else
					break;
			}
			if (n == tL) return i;
		}
	}
	return -1;
}

So aber noch genauer kann ich es nun nicht mehr hinschreiben! :)

bye Saxony
 

ska3k

Aktives Mitglied
Riesen Dank wirklich an euch alle, jetzt klappt perfekt! Auch wenn es bis dahin ein wenig gedauert hat ;)

Nur noch eine Frage, was deutet dieses source == null? Ist das das gleich, als wenn ich source == "" schreibe?
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
Temsky34 Array IndexOf nicht verfügbar Java Basics - Anfänger-Themen 18
M Erklärung: Int IndexOf (String s) Java Basics - Anfänger-Themen 3
P Schleife für insert() und delete() im StringBuilder in Verbindung mit indexOf() Java Basics - Anfänger-Themen 7
S fraglicher indexOf Wert Java Basics - Anfänger-Themen 2
X Erste Schritte Frage zu indexOf und startsWith Java Basics - Anfänger-Themen 6
P eigenes Equal mit IndexOf() Java Basics - Anfänger-Themen 5
B Arrays indexOf Java Basics - Anfänger-Themen 5
R indexOf wirft NullPointer Exception Java Basics - Anfänger-Themen 2
H Methoden indexOf Java Basics - Anfänger-Themen 11
A contains bzw. indexOf liefert keine Treffer? Java Basics - Anfänger-Themen 3
L String.indexOf -> Backslash Java Basics - Anfänger-Themen 3
B String Methoden ! substring,indexOf,length... :( Java Basics - Anfänger-Themen 5
S LinkedList indexOf() - geht des irgendwie schneller? Java Basics - Anfänger-Themen 23
B ArrayList<Double>.indexOf(Double)? Java Basics - Anfänger-Themen 2
K indexOf selbst rekursiv definieren Java Basics - Anfänger-Themen 4
StrikeTom ArrayList + IndexOf Java Basics - Anfänger-Themen 3
M IndexOf LinkedList Java Basics - Anfänger-Themen 2
G IndexOf Methode Java Basics - Anfänger-Themen 3
F indexOf weiter lesen Java Basics - Anfänger-Themen 14
G indexOf() Probleme Java Basics - Anfänger-Themen 8
B Char kommt 2 mal im Wort vor (indexOf) Java Basics - Anfänger-Themen 5
S indexOf(",") ? zeichenabfrage eines Strings Java Basics - Anfänger-Themen 7
G indexOf() - was bedeutet -1 ? Java Basics - Anfänger-Themen 27
J Indexof Java Basics - Anfänger-Themen 7
K Probleme mit indexOf() Java Basics - Anfänger-Themen 3
S Frage zu String.indexOf(String) Java Basics - Anfänger-Themen 22
T Rekursive Methode Java Basics - Anfänger-Themen 13
Ü Methode soll Quadrat aus der Summer zurückgeben Java Basics - Anfänger-Themen 10
P Objekt einer Methode eines anderen Objektes übergeben Java Basics - Anfänger-Themen 5
Leyla Spezifischte Methode Java Basics - Anfänger-Themen 16
M Methode zielnah zeigt das gewünschte Ausgabe nicht an Java Basics - Anfänger-Themen 3
L Variablenwerte aus einer Methode übergeben Java Basics - Anfänger-Themen 2
T Methode soll etwas ausrechnen und zurückgeben (klappt nd) hat wer eine Idee? Java Basics - Anfänger-Themen 11
P Main Methode scheint Constructor aufzurufen, ohne dass es so gecoded ist Java Basics - Anfänger-Themen 2
T Aufruf der Methode einer Oberklasse, wenn sie in der Unterklasse überschrieben ist. Polymorphie. Java Basics - Anfänger-Themen 2
C Zugriff auf Methode Java Basics - Anfänger-Themen 2
M Datentypen While-Schleife eine Java Methode erstellen Java Basics - Anfänger-Themen 3
T Methode akzeptiert String nicht Java Basics - Anfänger-Themen 18
M Methode sperren bis ein Kriterium erfüllt wurde Java Basics - Anfänger-Themen 3
D Switch Case Methode aufrufen Java Basics - Anfänger-Themen 3
C Unbekannte Methode add bei Klasse die JTree erweitert Java Basics - Anfänger-Themen 14
M methode aufrufen ohne parameter Java Basics - Anfänger-Themen 1
marcelnedza Finde meinen Fehler in einer Methode nicht, Java Karol Java Basics - Anfänger-Themen 15
monsterherz einfache Methode mit Fehler den ich nicht finde Java Basics - Anfänger-Themen 21
Ostkreuz Wieso wird die Methode nochmal aufgerufen? Java Basics - Anfänger-Themen 5
G Variable aktualisiert sich nicht in rekursiver Methode Java Basics - Anfänger-Themen 4
MoxMorris Wie macht man String[] = String[] aus einer anderer Methode? Java Basics - Anfänger-Themen 18
Say super.methode / super.variable und super(variable) Java Basics - Anfänger-Themen 2
B Wie kann ich folgende Klasse/Methode per Button ausführen? Java Basics - Anfänger-Themen 1
D Interface Methode wird ungewollt in der Subklasse überschrieben Java Basics - Anfänger-Themen 5
L Methoden Eine Methode um zu testen ob es ein Nachbar gibt Java Basics - Anfänger-Themen 10
til237 Iterative Methode in rekursive Methode umschreiben Java Basics - Anfänger-Themen 4
M Daten aus errechneter Methode in Datenbank(SQLite) schreiben Java Basics - Anfänger-Themen 60
D next() Methode mehrfach verwenden Java Basics - Anfänger-Themen 1
Ostkreuz Methoden Von Dezimal zu Hexadezimal Methode toHex Java Basics - Anfänger-Themen 2
I Entity Objekt nicht gefunden -> Webhook empfangen in der gleichen Methode (Transaktion) Java Basics - Anfänger-Themen 37
N Throw an Main Methode übergeben Java Basics - Anfänger-Themen 7
M Methoden Methode 'wiederhole' nicht gefunden (Uebersetzungsfehler) Java Basics - Anfänger-Themen 1
H Zu langen String aufteilen - bequeme Methode? Java Basics - Anfänger-Themen 14
_user_q Wie eine Methode/Funktion aus einer Klasse mit Constructor aufrufen? Java Basics - Anfänger-Themen 20
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
T Variable von Objekten in einer Methode überprüfen Java Basics - Anfänger-Themen 26
M Anzahl Kommandozeilenparamter mittels Methode Java Basics - Anfänger-Themen 11
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
frager2345 Problem mit Methode Java Basics - Anfänger-Themen 4
J Die statische Main-Methode ändert Instanzvariable? Java Basics - Anfänger-Themen 10
D Methode aus dem Aufrufer aufrufen Java Basics - Anfänger-Themen 1
T IOStreams read(byte[]b) methode Java Basics - Anfänger-Themen 2
frager2345 Java Singleton Muster -> Methode für Konstruktor mit Parametern Java Basics - Anfänger-Themen 3
U Beispiel Methode size() vom "Collection"-interface... Wie kann man sichtbar machen, was die Methode unter der Haube macht? Java Basics - Anfänger-Themen 8
D Warum kann ich hier nicht auf die Methode zugreifen? Java Basics - Anfänger-Themen 5
M generate Methode für Streams Java Basics - Anfänger-Themen 6
M Methoden Zweidimensionaler Array mit Setter Methode ändern Java Basics - Anfänger-Themen 4
I Optionaler Parameter bei Methode, der nur optional ist? Java Basics - Anfänger-Themen 6
berserkerdq2 Wozu benötigt man den BiPredicate, kann ich nicht einfach eine normale Methode nutzen, statt BiPredicate? Java Basics - Anfänger-Themen 3
T Linked List set-Methode Java Basics - Anfänger-Themen 2
D Arrays an replaceAll-Methode übergeben Java Basics - Anfänger-Themen 12
B Attribute eines Objekts einer Klasse durch statische Methode einer 2. Klasse ändern? Java Basics - Anfänger-Themen 32
berserkerdq2 Habe eine Klasse, welche public ist, diese hat eine public Methode, die nicht static ist. Wenn ich nun versuche aufzurufen Probleme? Java Basics - Anfänger-Themen 8
viktor1 Methoden Methode schreiben static void readText (String filename) {...} zu WordHistogramSample.java Java Basics - Anfänger-Themen 13
W Equals-Methode überschreiben bei composition Java Basics - Anfänger-Themen 20
V Hilfe bei Implementierung einer boolean Methode Java Basics - Anfänger-Themen 6
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
V Methoden printChar Methode mit Rückgabetyp void Java Basics - Anfänger-Themen 26
F Graph Tiefensuche Methode Java Basics - Anfänger-Themen 7
Jambolo Methode, welche die 3 letzten Parameter Werte speichert Java Basics - Anfänger-Themen 20
berserkerdq2 wie funktioniert contenthandler, was muss ich bei der Methode startElement und endElement tun? Java Basics - Anfänger-Themen 11
M Warum return die Methode den Wert nicht Java Basics - Anfänger-Themen 5
berserkerdq2 Wann soll ich den Stream schließen, wenn ich das in einer Methode habe? Java Basics - Anfänger-Themen 8
berserkerdq2 Ich gebe eine ArrayList als List zurück per MEthode, wie kann ich nun aber die ArrayList speichern? Java Basics - Anfänger-Themen 46
S Methode Java Basics - Anfänger-Themen 4
M Eine Methode die erkennt ob die ein gegebene zahl größer oder kleiner sein muss Java Basics - Anfänger-Themen 2
U Methode wird genutzt, ohne dass ich die aufrufe? Java Basics - Anfänger-Themen 4
F nach Methode Programm nicht beenden Java Basics - Anfänger-Themen 9
Liroyd Methode mit Objektvariabel rechnen? Java Basics - Anfänger-Themen 6
H Mit setter-Methode JLabel in einer andern Klasse ändern. Java Basics - Anfänger-Themen 40
D Methode um mögliche Rezepte auszugeben Java Basics - Anfänger-Themen 12
U Warum kann ich die Methode in der ENUM Klasse nicht aufrufen? Und warum geht die Switch nicht? Java Basics - Anfänger-Themen 8

Ähnliche Java Themen

Neue Themen


Oben