


Code écrit en C++ : recherchez la chaîne lexicographiquement la plus petite composée des K premières lettres de l'alphabet, et les caractères adjacents ne peuvent pas être identiques
Dans le monde de la programmation, résoudre des problèmes de manipulation de chaînes est un défi courant et intéressant. Un problème clé est de savoir comment obtenir une chaîne lexicographiquement minimale en utilisant uniquement les K lettres de l'alphabet, tout en respectant des contraintes supplémentaires telles que la non-correspondance des caractères adjacents. Dans cet article, nous visons à approfondir ce problème et à proposer une solution efficace utilisant le langage de programmation C++. En détaillant les différentes méthodes utilisées dans la grammaire et en fournissant des détails algorithmiques étape par étape, nous pouvons introduire des techniques innovantes visant à obtenir de bons résultats dans différents domaines. Nous fournissons des instructions complètes sur le code exécutable pour chaque méthode afin de la rendre pratique pour les utilisateurs.
Grammaire
Avant d'explorer les algorithmes et les techniques, il est nécessaire d'établir la syntaxe utilisée dans les extraits de code qui suivent.
std::string findLexSmallestString(int n, int k);
Dans cette syntaxe, n fait référence au nombre de lettres de l'alphabet, k fait référence au nombre de lettres utilisées et la fonction génère la chaîne ordonnée lexicographiquement la plus basse qui satisfait aux conditions spécifiées.
Algorithme
Pour relever et résoudre le défi consistant à trouver la chaîne lexicographiquement minimale sans répétition entre caractères adjacents en utilisant uniquement jusqu'à K lettres de l'alphabet, nous avons formulé une approche méthodique sous la forme d'un algorithme.
Initialisez une chaîne vide "ans" et un tableau/vecteur "used" pour suivre les caractères utilisés.
Commencez à itérer à partir du premier caractère de l'alphabet.
Ajoutez le caractère actuel à « ans » et marquez-le comme utilisé.
Si "ans" a plusieurs caractères et que les deux derniers caractères sont identiques, recherchez le prochain caractère disponible en itérant du caractère actuel jusqu'à "n".
Si aucun caractère disponible n'est trouvé, revenez en arrière en supprimant le dernier caractère de "ans" et en le marquant comme inutilisé.
Répétez les étapes 3 à 5 jusqu'à ce que « ans » atteigne la longueur « k ».
Renvoyez "ans" comme la plus petite chaîne lexicographique dans laquelle il n'y a pas deux caractères adjacents identiques, en utilisant toutes les premières K lettres de l'alphabet.
Méthode 1 : algorithme gourmand
Dans cette méthode, nous utiliserons une stratégie gloutonne pour construire la chaîne lexicographiquement la plus petite. Le même processus met l'accent sur un examen attentif de chaque caractère dans l'ordre tout en garantissant que les choix effectués tout au long du processus visent à minimiser la valeur lexicographique du résultat global.
Exemple
#include <iostream> #include <vector> std::string findLexSmallestGreedy(int n, int k) { std::string ans = ""; std::vector<bool> used(n, false); for (int i = 0; i < n; i++) { for (int j = 0; j < k; j++) { if (!used[j]) { if (ans.empty() || ans.back() != 'a' + j) { ans += 'a' + j; used[j] = true; break; } } } } return ans; } int main() { int n = 5; // Assuming there are 5 letters in the alphabet int k = 3; // Assuming 3 letters will be used std::string result = findLexSmallestGreedy(n, k); std::cout << "Lexicographically Smallest String: " << result << std::endl; return 0; }
Sortie
Lexicographically Smallest String: abc
Méthode 2 : Algorithme de retour en arrière
Cette stratégie consiste à utiliser le retour en arrière pour rechercher de manière exhaustive chaque combinaison de caractères tout en garantissant que les caractères consécutifs ne sont pas répétés. Par conséquent, en considérant chaque caractère à chaque position, nous pouvons trouver la chaîne lexicographiquement la plus petite qui satisfait les contraintes données.
Exemple
#include <iostream> #include <vector> bool findLexSmallestBacktracking(int n, int k, std::vector<char>& ans, std::vector<bool>& used) { if (ans.size() == k) { return true; } for (int i = 0; i < n; i++) { if (!used[i]) { if (ans.empty() || ans.back() != 'a' + i) { ans.push_back('a' + i); used[i] = true; if (findLexSmallestBacktracking(n, k, ans, used)) { return true; } ans.pop_back(); used[i] = false; } } } return false; } std::string findLexSmallestStringBacktracking(int n, int k) { std::vector<char> ans; std::vector<bool> used(n, false); if (findLexSmallestBacktracking(n, k, ans, used)) { return std::string(ans.begin(), ans.end()); } return ""; } int main() { int n = 22; // Assuming n = 22 int k = 4; // Assuming k = 4 std::string result = findLexSmallestStringBacktracking(n, k); std::cout << "Lexicographically Smallest String: " << result << std::endl; return 0; }
Sortie
Lexicographically Smallest String: abcd
Conclusion
Dans cet article, nous explorons le problème de trouver la chaîne lexicographiquement la plus petite en utilisant les K premières lettres de l'alphabet, avec la contrainte que deux caractères adjacents ne peuvent pas être identiques. Nous discutons de la syntaxe et proposons deux approches différentes pour résoudre ce problème : l'algorithme glouton et l'algorithme de retour en arrière. Les algorithmes gourmands emploient la stratégie consistant à minimiser la valeur lexicographique de la chaîne résultante, tandis que les algorithmes de backtracking explorent toutes les combinaisons possibles pour trouver la chaîne souhaitée. Les exemples de code C++ fournis démontrent l'implémentation de chaque méthode et nous permettent de générer efficacement des chaînes lexicographiquement minimales. Fort de ces connaissances, vous pouvez désormais résoudre en toute confiance des problèmes similaires de manipulation de chaînes et optimiser votre code en conséquence.
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

C Structure des données du langage: La représentation des données de l'arborescence et du graphique est une structure de données hiérarchique composée de nœuds. Chaque nœud contient un élément de données et un pointeur vers ses nœuds enfants. L'arbre binaire est un type spécial d'arbre. Chaque nœud a au plus deux nœuds enfants. Les données représentent StrustReenode {intdata; structTreenode * gauche; structureReode * droite;}; L'opération crée une arborescence d'arborescence arborescence (prédécision, ordre dans l'ordre et ordre ultérieur) Le nœud d'insertion de l'arborescence des arbres de recherche de nœud Graph est une collection de structures de données, où les éléments sont des sommets, et ils peuvent être connectés ensemble via des bords avec des données droites ou peu nombreuses représentant des voisins.

La vérité sur les problèmes de fonctionnement des fichiers: l'ouverture des fichiers a échoué: les autorisations insuffisantes, les mauvais chemins de mauvais et les fichiers occupés. L'écriture de données a échoué: le tampon est plein, le fichier n'est pas écrivatif et l'espace disque est insuffisant. Autres FAQ: traversée de fichiers lents, encodage de fichiers texte incorrect et erreurs de lecture de fichiers binaires.

C Guide de programmation multithreading Language: Création de threads: Utilisez la fonction PTHREAD_CREATE () pour spécifier l'ID de thread, les propriétés et les fonctions de thread. Synchronisation des threads: empêchez la concurrence des données via des mutex, des sémaphores et des variables conditionnelles. Cas pratique: utilisez le multi-lancement pour calculer le numéro Fibonacci, attribuer des tâches à plusieurs threads et synchroniser les résultats. Dépannage: résoudre des problèmes tels que les accidents de programme, les réponses d'arrêt de fil et les goulots d'étranglement des performances.

Comment produire un compte à rebours en C? Réponse: Utilisez des instructions de boucle. Étapes: 1. Définissez la variable N et stockez le numéro de compte à rebours à la sortie; 2. Utilisez la boucle while pour imprimer en continu n jusqu'à ce que n soit inférieur à 1; 3. Dans le corps de la boucle, imprimez la valeur de n; 4. À la fin de la boucle, soustrayez N par 1 pour sortir le prochain plus petit réciproque.

Les algorithmes sont l'ensemble des instructions pour résoudre les problèmes, et leur vitesse d'exécution et leur utilisation de la mémoire varient. En programmation, de nombreux algorithmes sont basés sur la recherche et le tri de données. Cet article présentera plusieurs algorithmes de récupération et de tri de données. La recherche linéaire suppose qu'il existe un tableau [20,500,10,5,100,1,50] et doit trouver le numéro 50. L'algorithme de recherche linéaire vérifie chaque élément du tableau un par un jusqu'à ce que la valeur cible soit trouvée ou que le tableau complet soit traversé. L'organigramme de l'algorithme est le suivant: Le pseudo-code pour la recherche linéaire est le suivant: Vérifiez chaque élément: Si la valeur cible est trouvée: return True return false C Implementation: # include # includeIntMain (void) {i

Les fonctions de langue C sont des blocs de code réutilisables, des paramètres de réception pour le traitement et des résultats de retour. Il est similaire au couteau suisse, puissant et nécessite une utilisation minutieuse. Les fonctions incluent des éléments tels que la définition des formats, des paramètres, des valeurs de retour et des corps de fonction. L'utilisation avancée comprend des pointeurs de fonction, des fonctions récursives et des fonctions de rappel. Les erreurs communes sont le type de type et oublier de déclarer les prototypes. Les compétences de débogage comprennent l'impression des variables et l'utilisation d'un débogueur. L'optimisation des performances utilise des fonctions en ligne. La conception des fonctions doit suivre le principe de la responsabilité unique. La maîtrise des fonctions du langage C peut améliorer considérablement l'efficacité de la programmation et la qualité du code.

C Structure des données du langage: Aperçu du rôle clé de la structure des données dans l'intelligence artificielle dans le domaine de l'intelligence artificielle, les structures de données sont cruciales pour traiter de grandes quantités de données. Les structures de données fournissent un moyen efficace d'organiser et de gérer les données, d'optimiser les algorithmes et d'améliorer l'efficacité du programme. Les structures de données courantes utilisées couramment les structures de données dans le langage C comprennent: les tableaux: un ensemble d'éléments de données stockés consécutivement avec le même type. Structure: un type de données qui organise différents types de données ensemble et leur donne un nom. Liste liée: une structure de données linéaire dans laquelle les éléments de données sont connectés ensemble par des pointeurs. Stack: Structure de données qui suit le dernier principe de premier-out (LIFO). File: Structure de données qui suit le premier principe de première sortie (FIFO). Cas pratique: le tableau adjacent dans la théorie des graphiques est l'intelligence artificielle

Dépannage des conseils pour les fichiers de traitement du langage C Lors du traitement des fichiers dans le langage C, vous pouvez rencontrer divers problèmes. Les problèmes suivants sont des problèmes communs et des solutions correspondantes: Problème 1: Impossible d'ouvrir le code de fichier: fichier * fp = fopen ("myfile.txt", "r"); if (fp == null) {// ouverture de fichier a échoué} Raison: le fichier d'erreur de fichier Fichier ne existe pas sans la lecture de fichier Code de lecture de fichier: Charbuffer [100]; size_tread_bytes = Fread (tampon, 1, siz
