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

C++の醜い数II


n番目の醜い数を見つけなければならないので、それを見つけることができるメソッドを定義する必要があるとします。醜い数は素因数が2、3、5しかない数であることがわかっているので、10番目の醜い数を見つけたい場合、最初のいくつかの醜い数は1、2、3であるため、12になります。 4、5、6、8、9、10、12

これを解決するには、次の手順に従います-

  • サイズn+1の配列vを作成します

  • n =1の場合、1を返します

  • 2:=2、3=3および5=5、towIndex:=2、threeIndex:=2およびfiveIndex:=2

  • 2からnの範囲のiの場合

    • curr:=2、3、5の最小値

    • v [i]:=curr

    • curr =2の場合、2:=v [twoIndex] * 2、twoIndexを1増やします

    • curr =3の場合、3:=v [threeIndex] * 3、threeIndexを1増やします

    • curr =5の場合、5:=v [fiveIndex] * 3、fiveIndexを1増やします

  • v [n]

    を返す

例(C ++)

理解を深めるために、次の実装を見てみましょう-

#include <bits/stdc++.h>
using namespace std;
class Solution {
   public:
   int nthUglyNumber(int n) {
      vector <int> v(n + 1);
      if(n == 1){
         return 1;
      }
      int two = 2, three = 3, five = 5;
      int twoIdx = 2;
      int threeIdx = 2;
      int fiveIdx = 2;
      for(int i = 2; i <= n; i++){
         int curr = min({two, three, five});
         v[i] = curr;
         if(curr == two){
            two = v[twoIdx] * 2;;
            twoIdx++;
         }
         if(curr == three){
            three = v[threeIdx] * 3;
            threeIdx++;
         }
         if(curr == five){
            five = v[fiveIdx] * 5;
            fiveIdx++;
         }
      }
      return v[n];
   }
};
main(){
   Solution ob;
   cout << (ob.nthUglyNumber(10));
}

入力

10

出力

12

  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 次の図から出力を確認できます- この問題については、可能な限り、これは一種のシリーズであるため、ソリューションでこのシリーズのパターンを見つけようと