


Comment trouver des sous-chaînes non répétitives en JavaScript
Dans le développement réel, nous devons souvent effectuer certaines opérations et traitements sur les chaînes, dont l'une consiste à trouver des sous-chaînes non répétitives. Par exemple, dans la chaîne « abcabcbb », la sous-chaîne non répétitive la plus longue est « abc », et dans la chaîne « bbbbbb », la sous-chaîne non répétitive la plus longue est « b ». Ces problèmes sont connus dans les algorithmes sous le nom de problème de « sous-chaîne non répétitive la plus longue », et nous pouvons les résoudre en utilisant JavaScript.
1. Méthode d'énumération violente
La méthode la plus simple consiste à utiliser la méthode d'énumération par force brute, c'est-à-dire à parcourir la chaîne à partir de zéro pour chaque caractère et à ajouter des caractères non répétitifs à la sous-chaîne un par un jusqu'à ce qu'une répétition soit rencontrée. Ensuite, enregistrez la longueur de la sous-chaîne à ce moment, réinitialisez la sous-chaîne et continuez à parcourir la chaîne vers le bas jusqu'à la fin du parcours.
Le code est le suivant :
function longestSubstring(str) { let maxLength = 0; // 定义最大长度为 0 for(let i = 0; i < str.length; i++) { let map = new Map(); // 定义 Map 来保存子串中元素出现的次数 let length = 0; // 定义子串长度为 0 for(let j = i; j < str.length; j++) { if(map.has(str[j])) { // 如果子串中已经有这个元素了 maxLength = Math.max(maxLength, length); // 更新最大长度 break; // 说明这个子串已经不符合要求了,跳出内部循环 } else { map.set(str[j], 1); // 在 Map 中记录该元素的出现次数 length++; // 子串长度 +1 maxLength = Math.max(maxLength, length); // 更新最大长度 } } } return maxLength; }
La complexité temporelle de cette méthode est O(n^3). Étant donné que le nombre de boucles imbriquées est très grand, son efficacité est très inefficace lors du traitement de chaînes plus longues.
2. Méthode de la fenêtre coulissante
Afin d'améliorer l'efficacité, nous pouvons utiliser la méthode de la fenêtre coulissante. L'idée de la fenêtre coulissante est de maintenir une fenêtre de longueur k et de faire glisser cette fenêtre pour traiter les chaînes. Dans ce problème, la longueur de la fenêtre glissante est la longueur de la chaîne non répétitive.
Plus précisément, lors du parcours d'une chaîne, nous définissons un pointeur de début et un pointeur de fin, et ces deux pointeurs formeront une fenêtre. Dans chaque boucle, si l'élément pointé par le pointeur de fin n'existe pas dans la fenêtre, on peut l'ajouter à la fenêtre, puis agrandir la fenêtre et mettre à jour la longueur de la fenêtre. Si l'élément pointé par le pointeur de fin existe déjà dans la fenêtre, nous devons déplacer le pointeur de début vers la droite et réduire la fenêtre jusqu'à ce que l'élément pointé par le pointeur de fin n'existe plus dans la fenêtre. Dans ce processus, nous devons utiliser une table de mappage pour enregistrer le nombre d'occurrences de chaque élément dans la fenêtre.
Le code est le suivant :
function longestSubstring(str) { let maxLength = 0; // 定义最大长度为 0 let map = new Map(); // 定义 Map 来保存元素出现的次数 let left = 0; // 定义左指针为 0 for(let right = 0; right < str.length; right++) { if(map.has(str[right])) { // 如果窗口内已经有该元素了 left = Math.max(left, map.get(str[right]) + 1); // 更新左指针,向右移动 } map.set(str[right], right); // 在 Map 中记录该元素的位置 maxLength = Math.max(maxLength, right - left + 1); // 更新最大长度 } return maxLength; }
La complexité temporelle de la méthode de fenêtre coulissante est O(n). Elle utilise HashMap pour localiser et stocker rapidement les caractères, ce qui est plus rapide et plus efficace que la méthode d'énumération par force brute.
3. Résumé
Pour le problème de sous-chaîne non répétitive le plus long dans une chaîne, nous pouvons utiliser deux méthodes pour le résoudre : la méthode d'énumération par force brute et la méthode de fenêtre glissante. La méthode d'énumération par force brute a une complexité temporelle élevée, tandis que la méthode de la fenêtre glissante est plus efficace. Dans le développement réel, nous pouvons choisir la méthode appropriée pour résoudre le problème selon nos besoins.
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!

Outils d'IA chauds

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

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

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

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)

L'article traite de l'utilisation Effecte dans React, un crochet pour gérer les effets secondaires comme la récupération des données et la manipulation DOM dans les composants fonctionnels. Il explique l'utilisation, les effets secondaires courants et le nettoyage pour éviter des problèmes comme les fuites de mémoire.

L'article explique l'algorithme de réconciliation de React, qui met à jour efficacement le DOM en comparant les arbres DOM virtuels. Il traite des avantages de la performance, des techniques d'optimisation et des impacts sur l'expérience utilisateur. Compte de charge: 159

Les fonctions d'ordre supérieur dans JavaScript améliorent la concision du code, la réutilisabilité, la modularité et les performances par abstraction, modèles communs et techniques d'optimisation.

L'article traite du curry dans JavaScript, une technique transformant les fonctions mulguments en séquences de fonctions à argument unique. Il explore la mise en œuvre du currying, des avantages tels que des applications partielles et des utilisations pratiques, améliorant le code

L'article discute de la connexion des composants React à Redux Store à l'aide de Connect (), expliquant MapStateToproprop, MapDispatchToprops et des impacts de performances.

L'article explique UseContext dans React, qui simplifie la gestion de l'État en évitant le forage des accessoires. Il traite des avantages tels que les améliorations centralisées de l'État et des performances grâce à des redevances réduites.

L'article discute de la prévention des comportements par défaut dans les gestionnaires d'événements à l'aide de la méthode empêchée dedEfault (), de ses avantages tels que une expérience utilisateur améliorée et des problèmes potentiels tels que les problèmes d'accessibilité.

L'article discute de la mise en œuvre de crochets personnalisés dans React, en se concentrant sur leur création, les meilleures pratiques, les avantages de la performance et les pièges communs à éviter.
