Table des matières
Exemple
Méthode 1
Algorithme
Sortie
Maison développement back-end C++ Programme Python pour générer des mots Lyndon de longueur n

Programme Python pour générer des mots Lyndon de longueur n

Aug 31, 2023 pm 09:29 PM
python 生成 长度

Programme Python pour générer des mots Lyndon de longueur n

Dans cette question, nous trouverons tous les mots Lyndon en utilisant un tableau de caractères alphanumériques.

Avant de commencer, comprenons d'abord la définition du mot Lyndon.

  • Tous les mots sont des mots Lyndon, strictement lexicographiquement plus petits que tous leurs cycles.

Voici des exemples de mots Lyndon.

  • ab - "ab" est strictement lexicographiquement plus petit que toutes ses permutations "ba".

  • 89 - La rotation de « 89 » est « 98 », qui est strictement lexicographiquement supérieure à « 89 ».

  • abc - Les rotations de 'abc' sont 'bca' et 'cab', qui sont strictement plus grandes que 'abc'.

Voici des exemples de mots non Lyndon.

  • aaa - aaa est un mot non Linden car toutes les rotations de "aaa" sont les mêmes.

  • bca - « bca » n'est pas un mot Linden car « abc » a une rotation plus petite que lui,

Énoncé du problème- On nous donne un tableau de caractères de longueur K contenant des caractères alphanumériques. De plus, on nous donne n contenant des entiers positifs. La tâche est que nous devons trouver tous les mots Lyndon de longueur n en utilisant les caractères alphanumériques donnés dans le tableau.

Exemple

Entrez

chars = ['1', '3', '2'], n = 3
Copier après la connexion

Sortie

112, 113, 122, 123, 132, 133, 223, 233
Copier après la connexion

Explication- Il génère tous les mots Lydon de longueur 3 en utilisant des caractères matriciels.

Entrez

 n = 2, chars = ['1', '0']
Copier après la connexion

Sortie

01
Copier après la connexion

Explication- "01" est le seul mot Lyndon que nous pouvons créer en utilisant des 0 et des 1.

Entrez

 n = 2, chars = ['c', 'a', 'd']
Copier après la connexion

Sortie

ac, ad, cd
Copier après la connexion

Explication- Il génère des mots Lyndon de longueur 2 en utilisant les caractères a, c et d.

Méthode 1

Nous avons un algorithme spécial pour générer des mots Linden appelé algorithme de Duval.

Algorithme

Étape 1- Définissez la valeur "n" qui représente la longueur du mot Lyndon et le tableau de caractères contenant les caractères à utiliser lors de la création du mot Lyndon.

Étape 2- Triez la liste.

Étape 3 − Initialisez la liste "index" avec −1.

Étape 4- Répétez jusqu'à ce que la liste d'index ne soit pas vide.

Étape 5- Augmentez le dernier élément de la liste "index" de 1.

Étape 6− Si list_size est égal à n, imprimez la valeur de la liste.

Étape 7- Ajoutez l'index à la liste afin que sa longueur soit égale à n.

Étape 8- Si le dernier élément de la liste est égal au dernier index du tableau, supprimez-le de la liste.

Exemple

Comprenons l'exemple avec un exemple de saisie.

  • La liste triée sera ['a', 'c', 'd'].

  • La liste d'index sera mise à jour de [−1] à [0] lors de la première itération. Après cela, la longueur de l'index est égale à 2 et devient [0, 0].

  • Dans la deuxième itération, la liste sera mise à jour à [0, 1] et nous trouverons le premier mot Lyndon "ac".

  • Dans la troisième itération, la liste deviendra [0, 2] et le deuxième mot Lyndon est "ad". De plus, le dernier élément est supprimé de la liste car il est égal à array_len -1.

  • Dans la quatrième itération, la liste deviendra [1]. [1, 1] sera mis à jour ultérieurement.

  • À la prochaine itération, la liste deviendra [1, 2] et on retrouve le troisième travail de Lyndon, ''cd'.

# Input
n = 2
chars = ['c', 'a', 'd']

# sort the list
initial_size = len(chars)
chars.sort()

# Initializing the list
indexes = [-1]

print("The Lyndon words of length {} is".format(n))

# Making iterations
while indexes:
    # Add 1 to the last element of the list
    indexes[-1] += 1
    list_size = len(indexes)

# If the list contains n characters, it means we found a Lyndon word
    if list_size == n:
        print(''.join(chars[p] for p in indexes))

    # Make the list size equal to n by adding characters
    while len(indexes) < n:
        indexes.append(indexes[-list_size])

    while indexes and indexes[-1] == initial_size - 1:
        indexes.pop()

Copier après la connexion

Sortie

The Lyndon words of length 2 is
ac
ad
cd
Copier après la connexion

Complexité temporelle− O(nlogn) car nous devons d'abord trier la liste des "caractères".

Complexité spatiale− O(n) puisque nous stockons n index dans la liste.

L'algorithme Duval est le moyen le plus efficace de générer des mots Lyndon de longueur n. Cependant, nous avons personnalisé la méthode pour utiliser uniquement des caractères de tableau.

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

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.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Où trouver la courte de la grue à atomide atomique
1 Il y a quelques semaines By DDD

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)

La vitesse de conversion est-elle rapide lors de la conversion du XML en PDF sur le téléphone mobile? La vitesse de conversion est-elle rapide lors de la conversion du XML en PDF sur le téléphone mobile? Apr 02, 2025 pm 10:09 PM

La vitesse du XML mobile à PDF dépend des facteurs suivants: la complexité de la structure XML. Méthode de conversion de configuration du matériel mobile (bibliothèque, algorithme) Méthodes d'optimisation de la qualité du code (sélectionnez des bibliothèques efficaces, optimiser les algorithmes, les données de cache et utiliser le multi-threading). Dans l'ensemble, il n'y a pas de réponse absolue et elle doit être optimisée en fonction de la situation spécifique.

Comment convertir les fichiers XML en PDF sur votre téléphone? Comment convertir les fichiers XML en PDF sur votre téléphone? Apr 02, 2025 pm 10:12 PM

Il est impossible de terminer la conversion XML à PDF directement sur votre téléphone avec une seule application. Il est nécessaire d'utiliser les services cloud, qui peuvent être réalisés via deux étapes: 1. Convertir XML en PDF dans le cloud, 2. Accédez ou téléchargez le fichier PDF converti sur le téléphone mobile.

Quelle est la fonction de la somme du langage C? Quelle est la fonction de la somme du langage C? Apr 03, 2025 pm 02:21 PM

Il n'y a pas de fonction de somme intégrée dans le langage C, il doit donc être écrit par vous-même. La somme peut être obtenue en traversant le tableau et en accumulant des éléments: Version de boucle: la somme est calculée à l'aide de la longueur de boucle et du tableau. Version du pointeur: Utilisez des pointeurs pour pointer des éléments de tableau, et un résumé efficace est réalisé grâce à des pointeurs d'auto-incitation. Allouer dynamiquement la version du tableau: allouer dynamiquement les tableaux et gérer la mémoire vous-même, en veillant à ce que la mémoire allouée soit libérée pour empêcher les fuites de mémoire.

Comment convertir XML en PDF sur votre téléphone? Comment convertir XML en PDF sur votre téléphone? Apr 02, 2025 pm 10:18 PM

Il n'est pas facile de convertir XML en PDF directement sur votre téléphone, mais il peut être réalisé à l'aide des services cloud. Il est recommandé d'utiliser une application mobile légère pour télécharger des fichiers XML et recevoir des PDF générés, et de les convertir avec des API Cloud. Les API Cloud utilisent des services informatiques sans serveur et le choix de la bonne plate-forme est crucial. La complexité, la gestion des erreurs, la sécurité et les stratégies d'optimisation doivent être prises en compte lors de la gestion de l'analyse XML et de la génération de PDF. L'ensemble du processus nécessite que l'application frontale et l'API back-end fonctionnent ensemble, et il nécessite une certaine compréhension d'une variété de technologies.

Comment convertir XML en images Comment convertir XML en images Apr 03, 2025 am 07:39 AM

XML peut être converti en images en utilisant un convertisseur XSLT ou une bibliothèque d'images. Convertisseur XSLT: Utilisez un processeur XSLT et une feuille de style pour convertir XML en images. Bibliothèque d'images: utilisez des bibliothèques telles que PIL ou ImageMagick pour créer des images à partir de données XML, telles que des formes de dessin et du texte.

Comment vérifier le format XML Comment vérifier le format XML Apr 02, 2025 pm 10:00 PM

La validation du format XML consiste à vérifier sa structure et sa conformité avec DTD ou schéma. Un analyseur XML est requis, tel que ElementTree (Basic Syntax Heatking) ou LXML (vérification plus puissante, prise en charge XSD). Le processus de vérification implique l'analyse du fichier XML, le chargement du schéma XSD et l'exécution de la méthode AssertValid pour lancer une exception lorsqu'une erreur est détectée. La vérification du format XML nécessite également de gérer diverses exceptions et de mieux comprendre le langage du schéma XSD.

Qui est payé plus de python ou de javascript? Qui est payé plus de python ou de javascript? Apr 04, 2025 am 12:09 AM

Il n'y a pas de salaire absolu pour les développeurs Python et JavaScript, selon les compétences et les besoins de l'industrie. 1. Python peut être davantage payé en science des données et en apprentissage automatique. 2. JavaScript a une grande demande dans le développement frontal et complet, et son salaire est également considérable. 3. Les facteurs d'influence comprennent l'expérience, la localisation géographique, la taille de l'entreprise et les compétences spécifiques.

Comment convertir XML en mp3 Comment convertir XML en mp3 Apr 03, 2025 am 09:00 AM

Les étapes pour convertir XML en MP3 incluent: Extraire les données audio de XML: analyser le fichier XML, trouver la chaîne de codage Base64 contenant les données audio et les décoder en format binaire. Encoder les données audio à MP3: Installez l'encodeur MP3 et définissez les paramètres de codage, encodez les données audio binaires au format MP3 et enregistrez-les dans un fichier.

See all articles