recherche
Maisondéveloppement back-endC++Comptez le nombre de nombres à N chiffres qui n'ont pas de préfixe donné

Comptez le nombre de nombres à N chiffres qui nont pas de préfixe donné

Le problème ici est de déterminer le nombre total de caractères « 0 » à « 9 » contenus dans une chaîne de longueur N, en fournissant un entier N et un tableau de préfixes de chaîne pre[] tel qu'il n'y en ait aucun dans ceux-ci. chaînes Un contenant le préfixe fourni. Le but de cet article est d'implémenter un programme qui trouve le nombre de nombres à N chiffres qui n'ont pas de préfixe donné.

En langage de programmation C, un ensemble de chaînes distinctes est appelé un tableau car un tableau est une combinaison linéaire d'un ensemble d'éléments de données de type similaire.

Comme nous le savons déjà, la chaîne est un tableau unidimensionnel caractère par caractère qui se termine par un caractère vide ou nul.

Exemple Exemple 1

Supposons l'entrée N = 2,

The given prefix, pre = {“1”}
Output obtained: 90

Explication

Ici, sauf {"01", "10", "11", "12", "13", "14", "15", "16", "17", "18", "19", Tous Les chaînes à 2 chiffres sauf "21", "31", "41", "51", "61", "71", "81", "91"} sont valides.

Exemple Exemple 2

Prenons la valeur d'entrée N = 3 comme exemple.

The given prefix, pre = {“56”}
Output obtained: 990

Explication

Ici, tout sauf {"560", "561", "562", "563", "564", "565", "566", "567", "568", "569"} chaînes à 3 chiffres sont tous valables.

Exemple Exemple 3

Regardons une entrée N = 1,

The given prefix, pre = {“6”}
Output obtained: 9

Explication

Toutes les chaînes à 1 chiffre ici sont valides sauf {"6"}.

Énoncé du problème

Implémentez un programme pour trouver le nombre de N chiffres qui n'ont pas de préfixe donné.

Méthode

Pour trouver le nombre de N chiffres sans donner de préfixe donné, on utilise la méthode suivante.

Solution à ce problème et trouver le chemin vers N nombre de chiffres qui n'a pas le préfixe donné

Considérant qu'il existe 10 options de caractères pour chaque position dans la chaîne, il y a (10N) chaînes potentielles au total. Au lieu de compter le nombre total de chaînes souhaitées, soustrayez le nombre total de chaînes dont vous ne voulez pas. La fusion de préfixes avec les mêmes caractères initiaux en un préfixe plus long avant l'itération peut entraîner la suppression de certains doublons.

Algorithme

Algorithme de recherche pour compter N chiffres qui n'ont pas le préfixe donné suivant

  • Première étape − Démarrer

  • Étape 2 - Définir une fonction pour compter le nombre total de chaînes de longueur N qui ne contiennent pas le préfixe donné

  • Étape 3 - Calculez le nombre total de chaînes existantes

  • Étape 4 - Créez un tableau et les compteurs a et aCount et insérez-y ces préfixes

  • Étape 5 − Créez un nouveau tableau de chaînes de préfixes

  • Étape 6 - Itérer pour chaque personnage de départ

  • Étape 7 - Parcourez le tableau pour calculer le préfixe de taille minimale

  • Étape 8 - Maintenant, mettez tous ces préfixes minimaux dans un nouveau tableau de préfixes

  • Étape 9 - Itérer sur de nouveaux préfixes

  • Étape 10 - Déduire les chaînes indésirables

  • Étape 11 − Imprimez les résultats obtenus

  • Étape 12 − Arrêtez

Exemple : programme C

Il s'agit d'une implémentation de programme C de l'algorithme ci-dessus pour trouver le nombre de N chiffres qui n'ont pas de préfixe donné.

#include <stdio.h>
#include <math.h>
#include <string.h>
#define MAX_LENGTH 10

// Function to calculate total strings of length N without the given prefixes
int totalStrings(int N, char pre[][MAX_LENGTH], int pre_Count){

   // Calculate total strings present
   int total = (int)(pow(10, N) + 0.5);
   
   // Make an array and counter a and aCount respectively and insert these prefixes with same character in the array
   char a[10][MAX_LENGTH];
   int aCount[10] = {0};
   for (int i = 0; i < pre_Count; i++)    {
      int index = pre[i][0] - '0';
      strcpy(a[index] + aCount[index] * MAX_LENGTH, pre[i]);
      aCount[index]++;
   }
   
   // Make a new array of prefixes strings
   char new_pre[pre_Count][MAX_LENGTH];
   int new_pre_count = 0;
   
   // Iterating for  each of the starting //character
   for (int x = 0; x < 10; x++){
      int m = N;
      
      // Iterate over the array to calculate minimum size prefix
      for (int j = 0; j < aCount[x]; j++){
         int p_length = strlen(a[x] + j * MAX_LENGTH);
         m = (m < p_length) ? m : p_length;
      }
      
      // now take all these minimum prefixes in the new array of prefixes
      for (int j = 0; j < aCount[x]; j++){
         int p_length = strlen(a[x] + j * MAX_LENGTH);
         if (p_length <= m){
            strcpy(new_pre[new_pre_count], a[x] + j * MAX_LENGTH);
            new_pre_count++;
         }
      }
   }
   
   // Iterating through the new prefixes
   for (int i = 0; i < new_pre_count; i++){
   
      // Subtract the unwanted strings
      total -= (int)(pow(10, N - strlen(new_pre[i])) + 0.5);
   }
   return total;
}

// The main function
int main(){
   int N = 5;
   char pre[][MAX_LENGTH] = {"1", "0", "2"};
   int pre_Count = sizeof(pre) / sizeof(pre[0]);
   printf("%d\n", totalStrings(N, pre, pre_Count));
   return 0;
}

Sortie

70000

Conclusion

De même, nous pouvons trouver le nombre de N chiffres qui n'ont pas le préfixe donné.

Dans cet article, le défi consistant à faire en sorte qu'un programme trouve un nombre à N chiffres qui n'a pas de préfixe donné est résolu.

Le code de programmation C est fourni ici avec l'algorithme pour trouver le nombre de nombres à N chiffres qui n'ont pas de préfixe donné.

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
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer
C destructeurs vs collecteurs d'ordures: quelles sont les différences?C destructeurs vs collecteurs d'ordures: quelles sont les différences?May 13, 2025 pm 03:25 PM

C destructeurs ProvidepreciseControloverResourcemangation, tandis que les destructeurs de destructeurs: 1) ont permis de permettre la réévaluation de l'autoroute: 1)

C et XML: intégrer les données dans vos projetsC et XML: intégrer les données dans vos projetsMay 10, 2025 am 12:18 AM

L'intégration de XML dans un projet C peut être réalisée via les étapes suivantes: 1) analyser et générer des fichiers XML à l'aide de la bibliothèque PUGIXML ou TinyXML, 2) Sélectionnez des méthodes DOM ou SAX pour l'analyse, 3) Gérer les nœuds imbriqués et les propriétés multi-niveaux, 4) Optimiser les performances à l'aide de techniques de débogage et de meilleures pratiques.

Utilisation de XML en C: un guide des bibliothèques et des outilsUtilisation de XML en C: un guide des bibliothèques et des outilsMay 09, 2025 am 12:16 AM

XML est utilisé en C car il fournit un moyen pratique de structurer les données, en particulier dans les fichiers de configuration, le stockage de données et les communications réseau. 1) Sélectionnez la bibliothèque appropriée, telle que TinyXML, PUGIXML, RapidXML et décider en fonction des besoins du projet. 2) Comprendre deux façons d'analyse et de génération XML: DOM convient à l'accès et à la modification fréquents, et le sax convient aux fichiers volumineux ou aux données de streaming. 3) Lors de l'optimisation des performances, TinyXML convient aux petits fichiers, PUGIXML fonctionne bien en mémoire et en vitesse, et RapidXML est excellent dans le traitement des fichiers volumineux.

C # et C: Explorer les différents paradigmesC # et C: Explorer les différents paradigmesMay 08, 2025 am 12:06 AM

Les principales différences entre C # et C sont la gestion de la mémoire, la mise en œuvre du polymorphisme et l'optimisation des performances. 1) C # utilise un collecteur de déchets pour gérer automatiquement la mémoire, tandis que C doit être géré manuellement. 2) C # réalise le polymorphisme à travers des interfaces et des méthodes virtuelles, et C utilise des fonctions virtuelles et des fonctions virtuelles pures. 3) L'optimisation des performances de C # dépend de la structure et de la programmation parallèle, tandis que C est implémenté via des fonctions en ligne et du multithreading.

C Analyse XML: techniques et meilleures pratiquesC Analyse XML: techniques et meilleures pratiquesMay 07, 2025 am 12:06 AM

Les méthodes DOM et SAX peuvent être utilisées pour analyser les données XML dans C. 1) DOM L'analyse DOM charge XML dans la mémoire, adaptée aux petits fichiers, mais peut prendre beaucoup de mémoire. 2) L'analyse du sax est motivée par des événements et convient aux fichiers volumineux, mais ne peut être accessible au hasard. Le choix de la bonne méthode et l'optimisation du code peuvent améliorer l'efficacité.

C dans des domaines spécifiques: explorer ses bastionsC dans des domaines spécifiques: explorer ses bastionsMay 06, 2025 am 12:08 AM

C est largement utilisé dans les domaines du développement de jeux, des systèmes intégrés, des transactions financières et de l'informatique scientifique, en raison de ses performances et de sa flexibilité élevées. 1) Dans le développement de jeux, C est utilisé pour un rendu graphique efficace et l'informatique en temps réel. 2) Dans les systèmes embarqués, la gestion de la mémoire de C et les capacités de contrôle du matériel en font le premier choix. 3) Dans le domaine des transactions financières, la performance élevée de C répond aux besoins de l'informatique en temps réel. 4) Dans l'informatique scientifique, les capacités de mise en œuvre de l'algorithme efficace de C et de traitement des données sont pleinement reflétées.

Debunking the Mythes: C est-il vraiment une langue morte?Debunking the Mythes: C est-il vraiment une langue morte?May 05, 2025 am 12:11 AM

C n'est pas mort, mais a prospéré dans de nombreux domaines clés: 1) le développement de jeux, 2) la programmation du système, 3) l'informatique haute performance, 4) les navigateurs et les applications réseau, C est toujours le choix grand public, montrant ses fortes scénarios de vitalité et d'application.

C # vs C: Une analyse comparative des langages de programmationC # vs C: Une analyse comparative des langages de programmationMay 04, 2025 am 12:03 AM

Les principales différences entre C # et C sont la syntaxe, la gestion de la mémoire et les performances: 1) la syntaxe C # est moderne, prend en charge Lambda et Linq, et C conserve les fonctionnalités C et prend en charge les modèles. 2) C # gère automatiquement la mémoire, C doit être géré manuellement. 3) Les performances C sont meilleures que C #, mais les performances C # sont également en cours d'optimisation.

See all articles

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 !

Article chaud

<🎜>: Bubble Gum Simulator Infinity - Comment obtenir et utiliser les clés royales
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
Mandragora: Whispers of the Witch Tree - Comment déverrouiller le grappin
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌
Nordhold: Système de fusion, expliqué
3 Il y a quelques semainesBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Puissant environnement de développement intégré PHP

Listes Sec

Listes Sec

SecLists est le compagnon ultime du testeur de sécurité. Il s'agit d'une collection de différents types de listes fréquemment utilisées lors des évaluations de sécurité, le tout en un seul endroit. SecLists contribue à rendre les tests de sécurité plus efficaces et productifs en fournissant facilement toutes les listes dont un testeur de sécurité pourrait avoir besoin. Les types de listes incluent les noms d'utilisateur, les mots de passe, les URL, les charges utiles floues, les modèles de données sensibles, les shells Web, etc. Le testeur peut simplement extraire ce référentiel sur une nouvelle machine de test et il aura accès à tous les types de listes dont il a besoin.

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

MinGW - GNU minimaliste pour Windows

MinGW - GNU minimaliste pour Windows

Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit