


Comment générer des combinaisons de permutation non répétitive basées sur un jeu de caractères et un nombre de couches, et exclure tous les caractères des mêmes combinaisons?
Génération efficace de disposition et de combinaison de caractères: éviter la duplication et exclure tout de même
Cet article décrit comment générer des combinaisons de permutation non répétitifs basées sur un jeu de caractères donné et un nombre de couches, et exclure efficacement les combinaisons où tous les caractères sont les mêmes. Par exemple, le jeu de caractères est «a» et «b», qui génère une combinaison de couches différentes: la première couche est «a», «b»; La deuxième couche est «ab», «ba» (à l'exclusion «aa», «bb»); La troisième couche contient «Aab», «Aba», «ABB», «baa», «bab», «bba», etc.
Nous adopterons deux stratégies d'algorithme: la méthode de remplacement numérique et la méthode de retournement.
Méthode 1: Méthode de remplacement numérique (plus concise)
Cette méthode traite les permutations comme des nombres à m-chiffre. Prenant le jeu de caractères 'A', 'B' comme exemple, 'A' IS 0 et 'B' IS 1. Combinaison de seconde couche: 00 ('AA'), 01 ('AB'), 10 ('BA'), 11 ('BB'). Itérer à travers tous les nombres de chiffre M et les convertir en combinaisons de caractères. Afin d'exclure la même combinaison, il est déterminé si le nombre de chiffres à m généré peut être divisible par (11 ... 1) (le nombre de 1 est égal au nombre de couches m).
Exemple de code python:
Def Generate_combinations (charset, couches, allow_all_same = false): résultats = [] n = len (charset) all_ones = sum (n ** i pour i dans la plage (couches))) pour i dans la gamme (couches n **): Si perte_all_same ou i% all_ones! = 0: #Exclude combinaison = "" temp = i pour _ dans la plage (couches): combinaison = combinaison de charset [temp% n] temp // = n ResultS.APPEND (combinaison) Résultats de retour print (generate_combinations ('ab', 2)) # ['ab', 'ba'] print (generate_combinations ('ab', 2, true)) # ['aa', 'ab', 'ba', 'bb'] print (generate_combinations ('ab', 3)) # ['aab', 'aba', 'abb', 'baa', 'bab', 'bba'] print (generate_combinations ('abc', 2)) # ['ab', 'ac', 'ba', 'bc', 'ca', 'cb']
Méthode 2: Méthode de retour en arrière (plus facile à comprendre)
Backtrace est un algorithme récursif qui essaie toutes les combinaisons. Ajoutez un caractère à la combinaison actuelle à chaque étape et génère récursivement des combinaisons plus longues. Utilisez l'indicateur pour déterminer si la combinaison de courant est le même caractère et évitez la duplication et la même combinaison.
Exemple de code python:
def generate_combinations_recursive (charse, couches, allow_all_same = false): résultats = [] Current_Combination = [''] * Couches Def BackTrack (index, all_same): Si index == couches: Si pas all_same: ResultS.APPEND ("". JOIN (current_combination)) Retour Pour Char in Charset: current_combination [index] = char BackTrack (Index 1, all_same et char == current_combination [index - 1] si index> 0 else false) Pour Char in Charset: current_combination [0] = char BackTrack (1, pas allow_all_same) Résultats de retour print (generate_combinations_recursive ('ab', 2)) # ['ab', 'ba'] print (generate_combinations_recursive ('ab', 2, true)) # ['aa', 'ab', 'ba', 'bb'] print (generate_combinations_recursive ('ab', 3)) # ['aab', 'aba', 'abb', 'baa', 'bab', 'bba'] print (generate_combinations_recursive ('ABC', 2)) # ['AB', 'AC', 'BA', 'BC', 'CA', 'CB']
Les deux méthodes peuvent résoudre efficacement le problème et le choix dépend de besoins et de préférences spécifiques. La méthode de remplacement numérique est plus simple et la méthode de retournement est plus facile à comprendre et à développer.
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

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

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)

Sujets chauds











PHP est principalement la programmation procédurale, mais prend également en charge la programmation orientée objet (POO); Python prend en charge une variété de paradigmes, y compris la POO, la programmation fonctionnelle et procédurale. PHP convient au développement Web, et Python convient à une variété d'applications telles que l'analyse des données et l'apprentissage automatique.

PHP convient au développement Web et au prototypage rapide, et Python convient à la science des données et à l'apprentissage automatique. 1.Php est utilisé pour le développement Web dynamique, avec une syntaxe simple et adapté pour un développement rapide. 2. Python a une syntaxe concise, convient à plusieurs champs et a un écosystème de bibliothèque solide.

Pour exécuter le code Python dans le texte sublime, vous devez d'abord installer le plug-in Python, puis créer un fichier .py et écrire le code, et enfin appuyez sur Ctrl B pour exécuter le code, et la sortie sera affichée dans la console.

PHP est originaire en 1994 et a été développé par Rasmuslerdorf. Il a été utilisé à l'origine pour suivre les visiteurs du site Web et a progressivement évolué en un langage de script côté serveur et a été largement utilisé dans le développement Web. Python a été développé par Guidovan Rossum à la fin des années 1980 et a été publié pour la première fois en 1991. Il met l'accent sur la lisibilité et la simplicité du code, et convient à l'informatique scientifique, à l'analyse des données et à d'autres domaines.

Python convient plus aux débutants, avec une courbe d'apprentissage en douceur et une syntaxe concise; JavaScript convient au développement frontal, avec une courbe d'apprentissage abrupte et une syntaxe flexible. 1. La syntaxe Python est intuitive et adaptée à la science des données et au développement back-end. 2. JavaScript est flexible et largement utilisé dans la programmation frontale et côté serveur.

Il existe quatre façons d'ajuster la liste des articles WordPress: utilisez des options de thème, utilisez des plugins (tels que l'ordre des types de publication, la liste des publiques WP, des trucs boxy), utilisez du code (ajoutez des paramètres dans le fichier functions.php), ou modifiez directement la base de données WordPress.

Golang est meilleur que Python en termes de performances et d'évolutivité. 1) Les caractéristiques de type compilation de Golang et le modèle de concurrence efficace le font bien fonctionner dans des scénarios de concurrence élevés. 2) Python, en tant que langue interprétée, s'exécute lentement, mais peut optimiser les performances via des outils tels que Cython.

L'écriture de code dans Visual Studio Code (VSCODE) est simple et facile à utiliser. Installez simplement VScode, créez un projet, sélectionnez une langue, créez un fichier, écrivez du code, enregistrez-le et exécutez-le. Les avantages de VSCOD incluent la plate-forme multiplateuse, gratuite et open source, des fonctionnalités puissantes, des extensions riches et des poids légers et rapides.
