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

C++の音楽プレイリストの数


N個の異なる曲を含む音楽プレーヤーがあり、旅行中にL個の曲を聴きたいとします。したがって、これらの条件を満たすようにプレイリストを作成する必要があります-

  • すべての曲が少なくとも1回再生されます

  • 曲を再度再生できるのは、他のK曲が再生された場合のみです。

可能なプレイリストの数を見つける必要があります。答えは非常に大きくなる可能性があるため、10 ^ 9+7を法として返します。

したがって、入力がN =2、L =3、K =0の場合、6つの可能なプレイリスト[1,1,2]、[1,2,1]、[2]があるため、出力は6になります。 、1,1]、[2,2,1]、[2,1,2]、[1,2,2]。

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

  • 関数add()を定義します。これには、a、b、

    が必要です。
  • return((a mod m)+(b mod m))mod m

  • 関数sub()を定義します。これには、a、b、

    が必要です。
  • return((a mod m)-(b mod m)+ m)mod m

  • 関数mul()を定義します。これにはa、b、

    が必要です。
  • return((a mod m)*(b mod m))mod m

  • メインの方法から、次のようにします-

  • サイズdp(L + 1)x(N + 1)の2次元配列を1つ作成します

  • dp [0、0]:=1

  • 初期化i:=1の場合、i <=Lの場合、更新(iを1増やします)、実行-

    • 初期化j:=1の場合、j <=Nの場合、更新(jを1増やします)、実行-

      • dp [i、j]:=mul(dp [i-1、j-1]、(N-(j-1)))

      • j> Kの場合、-

        • dp [i、j]:=add(dp [i、j]、mul(dp [i-1、j]、j-K))

  • dp [L、N]

    を返します

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

#include <bits/stdc++.h>
using namespace std;
const int m = 1e9 + 7;
typedef long long int lli;
class Solution {
   public:
   int add(lli a, lli b){
      return ((a % m) + (b % m)) % m;
   }
   int sub(lli a, lli b){
      return ((a % m) - (b % m) + m) % m;
   }
   int mul(lli a, lli b){
      return ((a % m) * (b % m)) % m;
   }
   int numMusicPlaylists(int N, int L, int K) {
      vector < vector <int> > dp(L + 1, vector <int>(N + 1));
      dp[0][0] = 1;
      for(int i = 1; i <= L; i++){
         for(int j = 1; j <= N; j++){
            dp[i][j] = mul(dp[i - 1][j - 1], (N - (j - 1)));
            if(j > K){
               dp[i][j] = add(dp[i][j], mul(dp[i - 1][j], j -
               K));
            }
         }
      }
      return dp[L][N];
   }
};
main(){
   Solution ob;
   cout << (ob.numMusicPlaylists(2, 3, 0));
}

入力

2,3,0

出力

6

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