Longueur minimale de chaîne après les opérations
Jan 13, 2025 pm 10:30 PM3223. Longueur minimale de la chaîne après les opérations
Difficulté :Moyen
Sujets : Table de hachage, chaîne, comptage
Vous recevez une chaîne s.
Vous pouvez effectuer le processus suivant n'importe quel nombre de fois :
- Choisissez un index i dans la chaîne tel qu'il y ait au moins un caractère à gauche de l'index i qui soit égal à s[i], et au moins un caractère à droite qui est également égal à s[i].
- Supprimer le caractère le plus proche à gauche de l'index i qui est égal à s[i].
- Supprimer le caractère le plus proche à droite de l'index i qui est égal à s[i].
Renvoyer la longueur minimale des chaînes finales que vous pouvez atteindre.
Exemple 1 :
- Entrée : s = "abaacbcbb"
- Sortie : 5
-
Explication : Nous effectuons les opérations suivantes :
- Choisissez l'index 2, puis supprimez les caractères aux indices 0 et 3. La chaîne résultante est s = "bacbcbb".
- Choisissez l'index 3, puis supprimez les caractères aux indices 0 et 5. La chaîne résultante est s = "acbcb".
Exemple 2 :
- Entrée : s = "aa"
- Sortie : 2
- Explication : Nous ne pouvons effectuer aucune opération, nous renvoyons donc la longueur de la chaîne d'origine.
Contraintes :
- 1 <= s.length <= 2 * 105
- s se compose uniquement de lettres anglaises minuscules.
Indice :
- Seule la fréquence de chaque caractère compte pour trouver la réponse finale.
- Si un personnage apparaît moins de 3 fois, nous ne pouvons effectuer aucun processus avec lui.
- Supposons qu'il y ait un caractère qui apparaît au moins 3 fois dans la chaîne, nous pouvons supprimer à plusieurs reprises deux de ces caractères jusqu'à ce qu'il en reste au plus 2 occurrences.
Solution :
Nous devons nous concentrer sur la fréquence de chaque caractère de la chaîne. Voici l’approche pour le résoudre :
Approche:
-
Compter les fréquences des caractères :
- Utilisez un tableau de fréquence pour compter combien de fois chaque caractère apparaît dans la chaîne.
-
Réduire les caractères avec une fréquence >= 3 :
- Si un caractère apparaît 3 fois ou plus, nous pouvons en supprimer deux à plusieurs reprises jusqu'à ce qu'il ne reste plus que 2 occurrences.
-
Calculer la longueur minimale :
- Résumez le nombre restant de tous les caractères après avoir réduit les fréquences.
-
Compte de fréquence :
- Parcourez la chaîne et pour chaque caractère, incrémentez son nombre dans le tableau $fréquence.
-
Réduction des Caractères:
- Pour chaque caractère du tableau $fréquence, vérifiez si son nombre est de 3 ou plus. Si c'est le cas, réduisez-le à 2 au maximum.
-
Calculer le résultat :
- Sommez les valeurs du tableau $fréquence pour obtenir la longueur minimale possible de la chaîne.
- Entrée : s = "abaacbcbb"
- Fréquences : ['a' => 3, 'b' => 4, 'c' => 2]
- Après réduction :
- 'a' => 2 (au lieu de 3),
- 'b' => 2 (au lieu de 4),
- 'c' => 2 (aucune réduction nécessaire).
- Longueur minimale : 2 2 2 = 6.
- Entrée : s = "aa"
- Fréquences : ['a' => 2]
- Aucune réduction nécessaire puisqu'aucun personnage n'a une fréquence de 3 ou plus.
- Longueur minimale : 2.
-
Complexité temporelle :
- Fréquences de comptage : O(n), où n est la longueur de la chaîne.
- Réduction : O(1) (temps constant, car il n'y a que 26 lettres minuscules).
- Fréquences de sommation : O(1).
- Global : O(n).
-
Complexité spatiale :
- O(1), puisque le tableau de fréquences a au plus 26 entrées.
- GitHub
Implémentons cette solution en PHP : 3223. Longueur minimale de la chaîne après les opérations
<?php /** * @param String $s * @return Integer */ function minimumLength($s) { ... ... ... /** * go to ./solution.php */ } // Example 1 $s1 = "abaacbcbb"; echo "Input: $s1\n"; echo "Output: " . minimumLength($s1) . "\n"; // Example 2 $s2 = "aa"; echo "Input: $s2\n"; echo "Output: " . minimumLength($s2) . "\n"; ?>
Explication:
Exemple de procédure pas à pas :
Exemple 1 :
Exemple 2 :
Complexité:
Cette solution est efficace et fonctionne bien dans les contraintes du problème.
Liens de contact
Si vous avez trouvé cette série utile, pensez à donner une étoile au référentiel sur GitHub ou à partager la publication sur vos réseaux sociaux préférés ?. Votre soutien signifierait beaucoup pour moi !
Si vous souhaitez du contenu plus utile comme celui-ci, n'hésitez pas à me suivre :
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

11 meilleurs scripts de raccourcissement d'URL PHP (gratuit et premium)

Travailler avec les données de session Flash dans Laravel

Misque de réponse HTTP simplifié dans les tests Laravel

Construisez une application React avec un Laravel Back End: Partie 2, React

Curl dans PHP: Comment utiliser l'extension PHP Curl dans les API REST

12 meilleurs scripts de chat PHP sur Codecanyon
