Maison > développement back-end > C++ > En C++, le nombre de chiffres du nième nombre composé des quatre nombres donnés

En C++, le nombre de chiffres du nième nombre composé des quatre nombres donnés

王林
Libérer: 2023-08-29 15:01:05
avant
632 Les gens l'ont consulté

En C++, le nombre de chiffres du nième nombre composé des quatre nombres donnés

Nous devons trouver le nombre de chiffres dans le nième nombre composé de quatre chiffres 1, 2, 3 et 4.

La série avec les quatre chiffres ci-dessus est la suivante

1, 2, 3, 4, 11, 12, 13, 14, 21, 22, 23, 24...

Nous devons trouver le nombre de chiffres du nième nombre de la série ci-dessus. Si vous observez attentivement le modèle, vous découvrirez les points suivants.

  • Il y a 4 nombres avec les chiffres 1.

  • Il y a 16 nombres avec les chiffres 2.

  • Le modèle continue avec les puissances de 4. .

Voyons un exemple

Entrée

7
Copier après la connexion

Sortie

2
Copier après la connexion

Le 7ème nombre de la série est 13 et le nombre de chiffres qu'elle contient est 2.

Algorithme

  • Initialisez le numéro n.
  • Initialisez deux variables, une pour stocker le résultat et une autre pour stocker la somme totale des nombres dans la série.
  • Créez une boucle qui augmente la variable itérative des puissances de 4.
    • Ajoutez le nombre actuel à la variable de somme .
    • Si la somme totale est supérieure à n, rompez la boucle.
    • Ajoutez 1 au résultat car le prochain ensemble de nombres aura un chiffre de plus que l'ensemble de nombres précédent.
  • Renvoyez le résultat.

Implémentation

Voici l'implémentation de l'algorithme ci-dessus en C++

#include <bits/stdc++.h>
using namespace std;
int getDigitsCount(int n) {
   int i, result = 1, sum = 0;
   for (i = 4; ; i *= 4) {
      sum += i;
      if (sum >= n) {
         break;
      }
      result += 1;
   }
   return result;
}
int main() {
   int n = 57;
   cout << getDigitsCount(n) << endl;
   return 0;
}
Copier après la connexion

输出

如果你运行上述代码,你将得到以下结果。

3
Copier après la connexion

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!

Étiquettes associées:
source:tutorialspoint.com
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal