亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

Table des matières
1. Introduction
2. Concept de base: déduplication des caractères de cha?ne
2.1 Méthode de déduplication basée sur Hashset
Maison Java javaDidacticiel Déduplication de caractère Java String et tutoriel de comptage de personnages partagé

Déduplication de caractère Java String et tutoriel de comptage de personnages partagé

Oct 01, 2025 am 02:30 AM

Déduplication de caractère Java String et tutoriel de comptage de personnages partagé

Ce didacticiel est destiné à guider les développeurs sur la fa?on de déduir efficacement les cha?nes Java et de calculer le nombre de caractères partagés entre chaque élément déducteur dans un tableau de cha?ne et une cha?ne déduplicate cible. L'article présentera en détail la méthode de déduplication de cha?ne basée sur HashSet, et la combinera avec des exemples complets de code Java pour montrer comment implémenter la logique exacte de correspondance et de comptage des caractères, et explorer également des considérations de performances pertinentes pour aider à optimiser les taches de traitement des cha?nes.

1. Introduction

Dans le cas du traitement des cha?nes, nous rencontrons souvent la nécessité de supprimer des caractères en double dans la cha?ne. Sur cette base, il est parfois nécessaire d'analyser davantage le partage des personnages entre différentes cha?nes. Ce tutoriel résoudra un problème spécifique: étant donné une cha?ne cible B et un tableau de cha?ne A, nous devons terminer les taches suivantes:

  1. Deduplicate la cha?ne cible B.
  2. Caractères de caractères dédupliqués pour chaque élément de cha?ne dans le tableau a.
  3. Calcule le nombre de caractères partagés entre chaque élément dans le tableau déducteur d'un tableau et la cha?ne B dédupliquée, et stocke ces comptes dans l'ordre dans un tableau entier.

Par exemple, si vous entrez b = "iyee" et a = ["hi", "bye", "bebe"], la sortie attendue est [1, 2, 1].

2. Concept de base: déduplication des caractères de cha?ne

La déduplication des caractères de cha?ne est la première étape pour résoudre ce problème. Son objectif est d'extraire tous les caractères non perpétitifs de la cha?ne et de les retourner sous forme de nouvelle cha?ne.

2.1 Méthode de déduplication basée sur Hashset

Hashset est une structure de données très pratique dans le cadre de la collection Java, qui stocke uniquement des éléments uniques. En utilisant cette fonctionnalité, nous pouvons implémenter efficacement la déduplication des caractères de cha?ne.

Principe: itérez à travers chaque caractère de la cha?ne d'entrée. Essayez d'ajouter chaque caractère au hashset. étant donné que HashSet n'autorise pas les éléments en double, seuls les caractères rencontrés pour la première fois peuvent être ajoutés avec succès. Dans le même temps, nous ajoutons les caractères ajoutés avec succès à un StringBuilder, et la cha?ne finale construite par StringBuilder est le résultat de la déduplication.

Exemple de code: Méthode DIST

 import java.util.hashset;
import java.util.set;

classe publique StringProcessor {

    / **
     * Deduplication de la cha?ne d'entrée, renvoyant une nouvelle cha?ne ne contenant que des caractères non répétés.
     *
     * @param s La cha?ne à déduir.
     * @return la cha?ne après déduplication.
     * /
    String statique public Dist (String S) {
        StringBuilder sb = new StringBuilder ();
        Set <comacter> set = new HashSet  ();
        pour (int i = 0; i <s.length i char currentchar="s.charat" si le caract est ajout avec succ l qu n pas apparu auparavant alors ajoutez stringbuilder if sb.append return sb.tostring ... autres m><p> <strong>expliquer:</strong></p>
<ul>
<li> StringBuilder sb = new StringBuilder ();: utilisé pour créer efficacement de nouvelles cha?nes de déduplication.</li>
<li> Set <comacter> set = new HashSet  ();: utilisé pour stocker des caractères uniques qui ont été rencontrés. La méthode set.add (currentChar) renvoie true lorsque l'élément n'existe pas et n'ajoute pas, et faux lorsqu'il existe.</comacter>
</li>
</ul>
<h3> 3. Stratégies de correspondance et de comptage des personnages</h3>
<p> Après avoir terminé la déduplication de cha?ne, l'étape suivante consiste à calculer le nombre de caractères partagés entre l'élément de tableau de déduplication et la cha?ne cible de déduplication. Cela calcule essentiellement la taille d'intersection de deux jeux de caractères.</p>
<p> <strong>Stratégie:</strong> Supposons que nous ayons deux cha?nes de déduplication S1 et S2. Pour calculer le nombre de caractères qu'ils partagent, nous pouvons itérer sur chaque personnage de S1, puis vérifier si ce personnage existe dans S2. Si elle est présente, le compteur est augmenté de un.</p>
<p> <strong>Exemple:</strong> si distinctb est "iye", distinct [i] est "salut":</p>
<ol><li> Traverser distinctb:<ul>
<li> Personnage 'i': Distinctarr [i] ("salut") contient 'i'? Oui. Count = 1.</li>
<li> Character 'y': Distinctarr [i] ("Hi") contient-il ?y?? Non.</li>
<li> Caractère 'e': Distinctarr [i] ("hi") contient-il 'e'? Non. Le décompte final est 1.</li>
</ul>
</li></ol>
<h3> 4. Tutoriel de mise en ?uvre complet</h3>
<p> Maintenant, nous intégrons le concept ci-dessus dans une méthode Java complète.</p>
<pre class="brush:php;toolbar:false">
import java.util.arrays; // introduire des tableaux pour les résultats d'impression. Classe publique StringProcessor {

    / **
     * Deduplication de la cha?ne d'entrée, renvoyant une nouvelle cha?ne ne contenant que des caractères non répétés.
     * Cette méthode a été expliquée en détail plus t?t.
     * /
    String statique public Dist (String S) {
        StringBuilder sb = new StringBuilder ();
        Set <comacter> set = new HashSet  ();
        pour (int i = 0; i <s.length i char currentchar="s.charat" if sb.append return sb.tostring traitez un tableau de cha d ses et cibles calculez le nombre caract partag b string cible. entier o chaque repr entre la correspondante a b. public static int mathprofessor deduplication cible distinct="dist" initialisez utilis pour stocker l comptage finale distinctrayelements="new" countarray="new" du distinctarrayelements dist effectuer correspondance des compter courantcount="0;" for traverse dans une courantdistinctelement="distinctArrayElements" j="0;" apr charfromdistinctb="distinctB.charat" v si les distinction actuelle sont contenus niveau actuel currentcount stockez r compteur retour void main args inputb="iyee" inputa='{"hi",' result="mathProfessor" system.out.println b: a: arrays.tostring sortie: sortie attendue: inputb2="Apple" inputa2='{"banane",' result2="mathProfessor" ninput> 1
                                                                    // "orag": 'a', 'e' (2) -> 2
                                                                    // "raisin": 'a', 'p', 'e' (3) -> 3. Oh attendez, mon manuel de vérification pour distincta2 est faux.
                                                                    // distincta2 = ["ban", "orage", "raisin"]
                                                                    // Réévaluez:
                                                                    // distinctb = "aple"
                                                                    // distincta [0] = "ban" -> 'a' dans "aple"? Oui. 'P' dans "Ban"? Non. "L 'dans" Ban "? Non. "E 'dans" Ban "? N ° COUNT = 1.
                                                                    // distincta [1] = "orage" -> 'o' dans "aple"? Non. 'R' dans "aple"? Non. 'A' dans "aple"? Oui. 'g' dans "aple"? Non. 'E' dans "aple"? Oui. Count = 2.
                                                                    // distincta [2] = "raisin" -> 'g' dans "aple"? Non. 'R' dans "aple"? Non. 'A' dans "aple"? Oui. 'p' dans "aple"? Oui. 'e' dans "aple"? Oui. Count = 3.
                                                                    // donc, le résultat2 devrait être [1, 2,</s.length></comacter>

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!

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

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Stock Market GPT

Stock Market GPT

Recherche d'investissement basée sur l'IA pour des décisions plus intelligentes

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Sujets chauds

Comment ajouter un fichier JAR au cours de classe en Java? Comment ajouter un fichier JAR au cours de classe en Java? Sep 21, 2025 am 05:09 AM

Utilisez le paramètre -cp pour ajouter le pot au ClassPath, afin que le JVM puisse charger ses classes et ressources internes, telles que Java-Cplibrary.jarcom.example.main, qui prend en charge plusieurs pots séparés par semi-colons ou couleurs, et peut également être configuré via des variables d'environnement de ClassPath Variables ou Manifest.mf.

Comment créer un fichier en java Comment créer un fichier en java Sep 21, 2025 am 03:54 AM

UseFile.CreateEnewFile () toCreateaFileOnlyiFitDoOesn’texist, EvitingoverWriting; 2.Preferfiles.CreateFile () FromNio.2Formodern, SafeFilecreationThatFailSiftheFileExists; 3.UseFileWriterorPrintwriterWistereAdMedimMedimate

Construire des applications extensibles avec l'interface de service de service Java (SPI) Construire des applications extensibles avec l'interface de service de service Java (SPI) Sep 21, 2025 am 03:50 AM

Javaspi est un mécanisme de découverte de service intégré dans JDK et met en ?uvre une expansion dynamique orientée vers l'interface via ServiceLoader. 1. Définissez l'interface de service et créez un fichier nommé avec le nom complet de l'interface sous Meta-Inf / Services /, et écrivez le nom entièrement qualifié de la classe d'implémentation; 2. Utilisez ServiceLoader.Load () pour charger la classe d'implémentation, et le JVM lira automatiquement la configuration et l'instanciera; 3. Le contrat d'interface doit être clarifié lors de la conception, de la priorité de support et du chargement conditionnel et fournit une implémentation par défaut; 4. Les scénarios d'application incluent l'accès au canal multi-paiement et la vérification du plug-in; 5. Faites attention aux performances, à ClassPath, à l'isolement des exceptions, à la sécurité des fils et à la compatibilité des versions; 6. Dans Java9, la fourniture peut être utilisée en combinaison avec des systèmes de modules.

Comment implémenter une interface dans Java? Comment implémenter une interface dans Java? Sep 18, 2025 am 05:31 AM

Utilisez le mot-clé Implements pour implémenter l'interface. La classe doit fournir des implémentations spécifiques de toutes les méthodes dans l'interface. Il prend en charge plusieurs interfaces et est séparé par des virgules pour s'assurer que les méthodes sont publiques. Les méthodes par défaut et statiques après Java 8 n'ont pas besoin d'être réécrites.

Comprendre les génériques Java et les jokers Comprendre les génériques Java et les jokers Sep 20, 2025 am 01:58 AM

JavagenerricsprovideCompile-TimetypePesafetyAndeliminateStingByAllowingTypeParameTersersonClasses, Interfaces et Methods; Wildcards (?,

Une compréhension approfondie des connexions persistantes HTTP: politiques et pratiques pour envoyer plusieurs demandes sur la même prise Une compréhension approfondie des connexions persistantes HTTP: politiques et pratiques pour envoyer plusieurs demandes sur la même prise Sep 21, 2025 pm 01:51 PM

Cet article explore en profondeur le mécanisme d'envoi de plusieurs demandes HTTP sur la même prise TCP, à savoir la connexion persistante HTTP (Keep-Alive). L'article clarifie la différence entre les protocoles HTTP / 1.x et HTTP / 2, souligne l'importance de la prise en charge c?té serveur pour les connexions persistantes et comment gérer correctement la connexion: fermer les en-têtes de réponse. En analysant les erreurs courantes et en fournissant les meilleures pratiques, nous visons à aider les développeurs à construire des clients HTTP efficaces et robustes.

Tutoriel Java: comment aplatir une liste de table imbriquée et remplir ses éléments dans un tableau Tutoriel Java: comment aplatir une liste de table imbriquée et remplir ses éléments dans un tableau Sep 18, 2025 am 07:24 AM

Ce didacticiel détaille comment traiter efficacement les listes de table imbriquées contenant d'autres listes de tableaux en Java et fusionner tous ses éléments internes en un seul tableau. L'article fournira deux solutions de base grace à l'opération FlatMap de l'API Java 8 Stream: aplatissant d'abord une liste, puis remplissant le tableau, et créant directement un nouveau tableau pour répondre aux besoins de différents scénarios.

Comment lire un fichier de propriétés en Java? Comment lire un fichier de propriétés en Java? Sep 16, 2025 am 05:01 AM

Utilisez la classe Properties pour lire facilement les fichiers de configuration Java. 1. Mettez Config.Properties dans le répertoire de ressources, chargez-le via getClassOader (). GetResourceAsStream () et appelez la méthode Load () pour lire la configuration de la base de données. 2. Si le fichier est dans un chemin externe, utilisez FileInputStream pour le charger. 3. Utilisez GetProperty (Key, DefaultValue) pour gérer les clés manquantes et fournir des valeurs par défaut pour garantir la gestion des exceptions et la vérification des entrées.

See all articles