


Remplacez chaque caractère d'une chaîne par le Kème caractère après sa fréquence exactement X fois
Dans ce problème, on nous donne une chaîne "str", un entier K et un entier X. La chaîne « str » contient uniquement des entiers compris entre 1 et 9. Nous devons effectuer X opérations sur cette chaîne. Le fonctionnement est qu'à chaque fois nous devons remplacer le nombre d'occurrences d'un caractère dans la chaîne par un caractère dans la chaîne. La fréquence fait ici référence au nombre ou à la valeur de caractères dans la chaîne. Notre tâche est de renvoyer le k-ème caractère après avoir effectué une opération donnée X fois.
Exemple
Input 1: str = “1231”, K = 5, X = 3
Output 1: 2
Instructions
Nous avons effectué l'opération donnée 3 fois.
1st time, str = 1223331 as
Pour le caractère str[0], la fréquence est 1 et la valeur est 1, donc 1 apparaît 1 fois.
Pour le caractère str[1], la fréquence est 2 et la valeur est 2, donc 2 apparaît 2 fois.
Les autres personnages sont similaires.
2nd time, str = 122223333333331 3rd time, str = 1222222223333333333333333333333333331
Donc exactement X fois plus tard, le Kème caractère de la chaîne est 2. La réponse est donc 2.
Input 2: str = “1121”, K = 2, X = 5
Output 2: 2
Nous avons vu l'exemple ci-dessus avec la chaîne donnée, passons aux méthodes -
Méthode naïve
Dans cette méthode, nous calculons la nouvelle chaîne en effectuant l'opération donnée jusqu'à X fois. Après avoir obtenu la chaîne exactement X fois, nous renvoyons le Kième caractère de la chaîne.
Exemple
Jetons un coup d'œil au code pour mieux comprendre la méthode ci-dessus -
#include <bits/stdc++.h> using namespace std; // Function to find the Kth character of the string after X times char findKthChar(string str, long long K, int X){ string s = str; // create another string to store the give string as we need to update the string for (int i = 0; i < X; i++) { string temp = ""; // To store the temporary result of each time for (int j = 0; j < s.size(); j++) { int freq = s[j] - '0'; // getting freq of char s[j] // adding char value its frequency times to 'temp' result. while (freq--) { temp += s[j]; } } s = temp; // update the string after. } return s[K - 1]; // return Kth character of X times string } int main(){ // Given Input string str = "1231"; long long K = 5; int X = 3; // Function Call char result = findKthChar(str, K, X); cout << result << "\n"; return 0; }
Sortie
2
Complexité temporelle et spatiale
La complexité temporelle dépend des nombres de chaînes donnés et est égale à la puissance x du nombre et à la somme de chaque nombre.
La complexité spatiale est exactement la même que la complexité temporelle.
Méthode efficace
Il s'agit d'une version optimisée de la méthode ci-dessus. où nous calculons la plage pour chaque charte X fois au lieu de créer une chaîne à chaque fois.
Ici, nous observons qu'à chaque fois le caractère augmente par rapport à la valeur du caractère élevée à la puissance du temps.
Discutons ci-dessous des principales étapes de la méthode ci-dessus -
Créez la variable kthChar pour stocker le KthChar de x fois la chaîne
Créez une variable tot pour stocker le nombre d'occurrences de chaque caractère après X fois
Utilisez une boucle for pour parcourir la chaîne et effectuez les étapes suivantes
Retour à kthChar
->Obtenir la valeur du personnage actuel
->En utilisant cette valeur et X, nous pouvons obtenir la plage du caractère actuel après X fois. Comme on peut l'observer, à chaque fois la valeur de force du personnage augmente de X
comme pow(valeur, X).
−> Stockez la plage dans la variable "tot" pour conserver la longueur de la chaîne après X fois
−> Vérifiez si le Kème caractère après X fois se trouve dans la longueur actuelle de la chaîne
As (K <= tot) si oui, cassez la boucle for et stockez le caractère actuel dans la variable "kthChar"<= tot) if yes 则中断 for 循环并将当前字符存储到变量“kthChar”
Exemple
#include <bits/stdc++.h> using namespace std; // Function to find the Kth character of the string after X times char findKthChar(string str, long long K, int X){ char kthChar; // Variable to store the KthChar of x times string int tot = 0; // to store the count of the each character occur after the X times // Traverse the string 'str' for (int i = 0; i < str.size(); i++) { int value = str[i] - '0'; // Convert char into int to get the value // Calculate each characters occuring range int charRange = pow(value, X); tot += charRange; // If K is less than tot than kthChar is str[i] if (K <= tot) { kthChar = str[i]; break; // break the for loop } } // Return answer, kthChar of the string after X times return kthChar; } int main(){ string str = "1231"; // given string long long K = 5; // given integer int X = 3; // given integer // Function Call to get the kth character after X times char result = findKthChar(str, K, X); // Print the result cout << result << "\n"; return 0; }
Sortie
2
Complexité temporelle et spatiale
La complexité temporelle du code ci-dessus est O(N), où N est la taille de la longueur donnée.
La complexité spatiale du code ci-dessus est O(1) car nous n'utilisons aucun espace supplémentaire.
Conclusion
Dans ce tutoriel, nous avons implémenté un programme pour trouver le Kième caractère dans une chaîne après avoir remplacé chaque caractère par sa fréquence exactement X fois. Nous avons mis en œuvre deux méthodes, l’une est la méthode naïve et l’autre la méthode efficace.
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)

Explication détaillée de la méthode de conversion du type int en chaîne en PHP Dans le développement PHP, nous rencontrons souvent le besoin de convertir le type int en type chaîne. Cette conversion peut être réalisée de différentes manières. Cet article présentera en détail plusieurs méthodes courantes, avec des exemples de code spécifiques pour aider les lecteurs à mieux comprendre. 1. Utilisez la fonction intégrée strval() de PHP. PHP fournit une fonction intégrée strval() qui peut convertir des variables de différents types en types de chaîne. Lorsque nous devons convertir le type int en type chaîne,

1. Ouvrez d’abord pycharm et accédez à la page d’accueil de pycharm. 2. Créez ensuite un nouveau script python, cliquez avec le bouton droit sur nouveau - cliquez sur fichier python. 3. Entrez une chaîne, code : s="-". 4. Ensuite, vous devez répéter les symboles de la chaîne 20 fois, code : s1=s*20 5. Entrez le code de sortie d'impression, code : print(s1). 6. Enfin, exécutez le script et vous verrez notre valeur de retour en bas : - répété 20 fois.

Titre : Comment déterminer si une chaîne se termine par un caractère spécifique en Golang. Dans le langage Go, nous devons parfois déterminer si une chaîne se termine par un caractère spécifique. Ceci est très courant lors du traitement de chaînes. Cet article explique comment utiliser le langage Go pour implémenter cette fonction et fournit des exemples de code pour votre référence. Voyons d’abord comment déterminer si une chaîne se termine par un caractère spécifié dans Golang. Les caractères d'une chaîne dans Golang peuvent être obtenus par indexation, et la longueur de la chaîne peut être

Comment vérifier si une chaîne commence par un caractère spécifique en Golang ? Lors de la programmation en Golang, vous rencontrez souvent des situations où vous devez vérifier si une chaîne commence par un caractère spécifique. Pour répondre à cette exigence, nous pouvons utiliser les fonctions fournies par le package strings dans Golang pour y parvenir. Ensuite, nous présenterons en détail comment utiliser Golang pour vérifier si une chaîne commence par un caractère spécifique, avec des exemples de code spécifiques. En Golang, nous pouvons utiliser HasPrefix du package strings

Méthodes pour résoudre le problème des caractères chinois tronqués lors de la conversion de chaînes hexadécimales en PHP. Dans la programmation PHP, nous rencontrons parfois des situations où nous devons convertir des chaînes hexadécimales en caractères chinois normaux. Cependant, au cours du processus de conversion, vous rencontrerez parfois le problème des caractères chinois tronqués. Cet article vous fournira une méthode pour résoudre le problème des caractères chinois tronqués lors de la conversion de caractères hexadécimaux en chaîne en PHP, et donnera des exemples de code spécifiques. Utilisez la fonction hex2bin() pour la conversion hexadécimale. La fonction hex2bin() intégrée de PHP peut convertir 1.

Le langage Go est un langage de programmation puissant et flexible qui fournit de riches fonctions de traitement de chaînes, notamment l'interception de chaînes. Dans le langage Go, nous pouvons utiliser des tranches pour intercepter des chaînes. Ensuite, nous présenterons en détail comment intercepter des chaînes en langage Go, avec des exemples de code spécifiques. 1. Utilisez le découpage pour intercepter une chaîne. Dans le langage Go, vous pouvez utiliser des expressions de découpage pour intercepter une partie d'une chaîne. La syntaxe de l'expression slice est la suivante : slice:=str[start:end]where, s

Opération de chaîne PHP : une méthode pratique pour supprimer efficacement les espaces Dans le développement PHP, vous rencontrez souvent des situations dans lesquelles vous devez supprimer des espaces d'une chaîne. La suppression des espaces peut rendre la chaîne plus propre et faciliter le traitement et l'affichage ultérieurs des données. Cet article présentera plusieurs méthodes efficaces et pratiques pour supprimer des espaces et joindra des exemples de code spécifiques. Méthode 1 : utilisez la fonction intégrée PHP trim() La fonction intégrée PHP trim() peut supprimer les espaces aux deux extrémités de la chaîne (y compris les espaces, les tabulations, les nouvelles lignes, etc.), ce qui est très pratique et simple. utiliser.

Opération de chaîne PHP : supprimer les virgules supplémentaires et conserver uniquement les virgules. Conseils d'implémentation Dans le développement PHP, le traitement des chaînes est une exigence très courante. Parfois, nous devons traiter la chaîne pour supprimer les virgules supplémentaires et conserver les seules virgules. Dans cet article, je présenterai une technique d'implémentation et fournirai des exemples de code concrets. Tout d’abord, examinons une exigence courante : supposons que nous ayons une chaîne contenant plusieurs virgules et que nous devions supprimer les virgules supplémentaires et conserver uniquement la virgule unique. Par exemple, remplacez "apple,ba
