Maison > développement back-end > C++ > Quelle est la façon la plus efficace de compter les occurrences de caractère ou de chaîne dans une chaîne?

Quelle est la façon la plus efficace de compter les occurrences de caractère ou de chaîne dans une chaîne?

Susan Sarandon
Libérer: 2025-01-31 06:31:12
original
255 Les gens l'ont consulté

What's the Most Efficient Way to Count Character or String Occurrences in a String?

Caractères ou chaînes statistiques efficaces dans la chaîne de caractères

Lorsque le nombre de caractères cibles ou de chaîne doit apparaître dans une chaîne plus longue, les développeurs considèrent généralement plusieurs méthodes. Deux méthodes courantes incluent la différence de longueur de la longueur de la chaîne à l'aide de la fonction de remplacement, ou divisez la chaîne en fonction du caractère cible.

Cependant, .NET 3.5 fournit une solution plus efficace: la méthode du nombre de linq. Cela permet le nombre dans une ligne de code:

Parmi eux, Source est une chaîne à rechercher, // est un personnage qui veut compter.
<code>int count = source.Count(f => f == '/');</code>
Copier après la connexion

Une autre méthode consiste à utiliser la méthode divisée:

Bien que ces deux méthodes fournissent une alternative concise, le test de référence montre que la méthode de calcul de la différence de longueur entre le calcul de la fonction de remplacement est encore étonnamment rapide. Par exemple, pour la chaîne "/ une fois / on / a / time /", la méthode de remplacement consomme 12 secondes en itération à 50 000 000 fois, et la méthode de comptage prend 19 secondes, et la méthode divisée prend 17 secondes.
<code>int count = source.Split('/').Length - 1;</code>
Copier après la connexion

En fin de compte, les développeurs doivent choisir le plus conformément à leurs besoins et préférences spécifiques. Cependant, lorsque les performances deviennent un point de mise au point, la méthode d'origine d'utilisation de la fonction de remplacement est toujours un choix possible et efficace.

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!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal