Table des matières
Grammaire
Algorithme
Méthode 1 : algorithme gourmand
Exemple
Sortie
Méthode 2 : Algorithme de retour en arrière
Conclusion
Maison développement back-end C++ 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

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

Aug 29, 2023 pm 10:29 PM
c语言 personnages adjacents Tri par dictionnaire

Code écrit en C++ : recherchez la chaîne lexicographiquement la plus petite composée des K premières lettres de lalphabet, 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);
Copier après la connexion

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;
}
Copier après la connexion

Sortie

Lexicographically Smallest String: abc
Copier après la connexion

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;
}
Copier après la connexion

Sortie

Lexicographically Smallest String: abcd
Copier après la connexion

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!

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

Video Face Swap

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 !

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)

C Structure des données du langage: représentation des données et fonctionnement des arbres et des graphiques C Structure des données du langage: représentation des données et fonctionnement des arbres et des graphiques Apr 04, 2025 am 11:18 AM

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é derrière le problème de fonctionnement du fichier de langue C La vérité derrière le problème de fonctionnement du fichier de langue C Apr 04, 2025 am 11:24 AM

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 Programmation multithread du langage: Guide du débutant et dépannage C Programmation multithread du langage: Guide du débutant et dépannage Apr 04, 2025 am 10:15 AM

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 dans le langage C Comment produire un compte à rebours dans le langage C Apr 04, 2025 am 08:54 AM

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.

CS-semaine 3 CS-semaine 3 Apr 04, 2025 am 06:06 AM

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

Le concept des fonctions du langage C et leur format de définition Le concept des fonctions du langage C et leur format de définition Apr 03, 2025 pm 11:33 PM

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: Le rôle clé des structures de données dans l'intelligence artificielle C Structure des données du langage: Le rôle clé des structures de données dans l'intelligence artificielle Apr 04, 2025 am 10:45 AM

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 le traitement des fichiers dans la langue C Dépannage des conseils pour le traitement des fichiers dans la langue C Apr 04, 2025 am 11:15 AM

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

See all articles