Heim >Java >javaLernprogramm >Wie kann man Teilstring-Vorkommen in einem String effizient zählen?

Wie kann man Teilstring-Vorkommen in einem String effizient zählen?

Barbara Streisand
Barbara StreisandOriginal
2024-12-18 13:54:10827Durchsuche

How to Efficiently Count Substring Occurrences in a String?

Vorkommen von Teilzeichenfolgen in einer Zeichenfolge finden

Im folgenden Code besteht unser Ziel darin, zu bestimmen, wie oft die Teilzeichenfolge findStr innerhalb der Zeichenfolge vorkommt string str:

String str = "helloslkhellodjladfjhello";
String findStr = "hello";
int lastIndex = 0;
int count = 0;

while (lastIndex != -1) {
    lastIndex = str.indexOf(findStr, lastIndex);

    if (lastIndex != -1)
        count++;

    lastIndex += findStr.length();
}

System.out.println(count);

Dieser Algorithmus kann jedoch unter bestimmten Umständen nicht beendet werden. Das Problem liegt darin, dass lastIndex = findStr.length() dazu führen kann, dass der Algorithmus über das Ende der Zeichenfolge hinaus sucht. Um dieses Problem zu lösen, können wir stattdessen den folgenden Ansatz verwenden:

String str = "helloslkhellodjladfjhello";
String findStr = "hello";
int count = StringUtils.countMatches(str, findStr);
System.out.println(count);

Dieser Code verwendet die StringUtils.countMatches-Methode von Apache Commons Lang, die eine robustere und effizientere Lösung zum Zählen des Vorkommens von Teilzeichenfolgen bietet.

Das obige ist der detaillierte Inhalt vonWie kann man Teilstring-Vorkommen in einem String effizient zählen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn