


Pourquoi mon algorithme de comptage de sous-chaînes ne s'arrête-t-il pas ?
Dec 15, 2024 pm 08:31 PMPourquoi l'algorithme donné ne s'arrête-t-il pas ?
Dans l'algorithme fourni, une tentative est faite pour trouver le nombre d'occurrences d'une sous-chaîne dans une chaîne. Cependant, l'algorithme est conçu pour continuer jusqu'à ce que le dernier index de la sous-chaîne de la chaîne devienne -1. Cette condition ne sera jamais remplie car le dernier index est toujours mis à jour en y ajoutant la longueur de la sous-chaîne. En conséquence, l'algorithme continuera à rechercher la sous-chaîne indéfiniment, sans jamais se terminer.
Utiliser Apache Commons Lang pour le comptage des sous-chaînes
Une approche alternative pour compter les occurrences de sous-chaîne est pour utiliser la méthode StringUtils.countMatches d'Apache Commons Lang. Cette méthode prend une chaîne et une sous-chaîne comme arguments et renvoie le nombre de fois où la sous-chaîne apparaît dans la chaîne. En utilisant cette méthode, le problème d'origine peut être résolu avec le code suivant :
String str = "helloslkhellodjladfjhello"; String findStr = "hello"; System.out.println(StringUtils.countMatches(str, findStr));
Ce code renvoie :
3
qui compte correctement les occurrences de la sous-chaîne "hello" dans le chaîne "helloslkhellodjladfjhello".
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Comment fonctionne le mécanisme de chargement de classe de Java, y compris différents chargeurs de classe et leurs modèles de délégation?

Top 4 frameworks JavaScript en 2025: React, Angular, Vue, Svelte

Comment puis-je utiliser JPA (Java Persistance API) pour la cartographie relationnelle des objets avec des fonctionnalités avancées comme la mise en cache et le chargement paresseux?

Comment utiliser Maven ou Gradle pour la gestion avancée de projet Java, la création d'automatisation et la résolution de dépendance?

Node.js 20: Boosts de performances clés et nouvelles fonctionnalités

Iceberg: L'avenir des tables de Data Lake

Spring Boot SnakeyAml 2.0 CVE-2022-1471 Issue fixe

Comment puis-je implémenter des techniques de programmation fonctionnelle en Java?
