C ++
 Computer >> コンピューター >  >> プログラミング >> C ++

C++でのK番目のブーム番号


このチュートリアルでは、k番目のブーム番号を見つけるプログラムを作成します。

2と3だけを含む番号はブーム番号と呼ばれます。

上記の問題を解決するための手順を見てみましょう。

  • kの値を初期化します。
  • 文字列のキューを初期化します。
  • 空の文字列をキューにプッシュします。
  • カウンタ変数を0に初期化します。
  • カウンターが指定されたk以下になるまで繰り返すループを記述します。
    • キューの先頭に立つ。
    • キューから要素をポップします。
    • キューの先頭を変数に格納します。
    • 先頭に2を付けた後、番号を押します。
    • カウンターをインクリメントし、kがカウンターと等しいかどうかを確認します。
    • カウンターがkに等しい場合は、値を出力してブレークします。
    • 先頭に3を付けた後、番号を押します。
    • カウンターをインクリメントし、kがカウンターと等しいかどうかを確認します。
    • カウンターをインクリメントし、kがカウンターと等しいかどうかを確認します。

コードを見てみましょう。

#include<bits/stdc++.h>
using namespace std;
void findKthBoomNumber(long long k) {
   queue<string> queue;
   queue.push("");
   long long count = 0;
   while (count <= k) {
      string numberOne = queue.front();
      queue.pop();
      string numberTwo = numberOne;
      queue.push(numberOne.append("2"));
      count++;
      if (count == k) {
         cout << numberOne << endl;
         break;
      }
      queue.push(numberTwo.append("3"));
      count++;
      if (count == k) {
         cout << numberTwo << endl;
         break;
      }
   }
}
int main() {
   long long k = 45;
   findKthBoomNumber(k);
   return 0;
}

出力

上記のコードを実行すると、次の結果が得られます。

23332

結論

チュートリアルに質問がある場合は、コメントセクションにそのことを記載してください。


  1. C++での質素な数

    この問題では、正の整数Nが与えられます。私たちのタスクは、与えられた数が質素な数であるかどうかをチェックするプログラムを作成することです。 不正な番号 −指定された数の素因数分解の桁数よりも厳密に桁数が多い数。 例 − 625、数625の素因数は5 4です。 。 625の桁数は3です。 5 4の桁数 は2です。 3は厳密に2より大きくなります。したがって、625は質素な数です。 最初のいくつかの質素な数は − 125、128、243、256、343、512、625など。 問題を理解するために例を見てみましょう Input: n = 128 Output: Frugal n

  2. C++五胞体数

    五胞体数は、パスカルの三角形の5番目の数として表されます。ご存知のように、これは5番目の数字です。つまり、パスカルの三角形に少なくとも5つの数字が必要です。したがって、このシリーズの最初の数字は 1 4 6 4 1から始まります。 パスカルの三角形の4行目。したがって、このチュートリアルでは、たとえば、n番目の五胞体数を見つける必要があります Input : 1 Output : 1 Input : 4 Output : 35 次の図から出力を確認できます- この問題については、可能な限り、これは一種のシリーズであるため、ソリューションでこのシリーズのパターンを見つけようと