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
Freigeben: 2024-12-18 13:54:10
Original
821 Leute haben es durchsucht

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);
Nach dem Login kopieren

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);
Nach dem Login kopieren

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!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage