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

C ++でRand7()を使用してRand10()を実装する


1〜7の範囲の均一なランダム整数を生成する関数rand7があるとします。1〜10の範囲の均一なランダム整数を生成する別の関数rand10を作成する必要があります。一部のライブラリ関数を使用して乱数を生成することはできません。

2つの乱数が必要であるとすると、[8,10]になる可能性があります。

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

  • rand40:=40
  • while rand40> =40
    • rand40:=(rand7()-1)* 7 +(rand7()– 1)
  • rand40 mod 10+1を返す

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

#include <bits/stdc++.h>
using namespace std;
int rand7(){
   return 1 + rand() % 7;
}
class Solution {
   public:
   int rand10() {
      int rand40 = 40;
      while(rand40 >= 40){
         rand40 = (rand7() - 1) * 7 + (rand7() - 1);
      }
      return rand40 % 10 + 1;
   }
};
main(){
   srand(time(NULL));
   Solution ob;
   cout << (ob.rand10()) << endl;
   cout << (ob.rand10()) << endl;
   cout << (ob.rand10()) << endl;
}

入力

Call the function three times

出力

2
2
6

  1. セットを使用してダイクストラのアルゴリズムを実装するC++プログラム

    これは、Setを使用してダイクストラのアルゴリズムを実装するためのC++プログラムです。ここでは2つのセットが必要です。ルートとして指定されたソースノードを使用して最短パスツリーを生成します。 1つのセットには最短経路ツリーに含まれる頂点が含まれ、もう1つのセットにはまだ最短経路ツリーに含まれていない頂点が含まれます。すべてのステップで、他のセット(まだ含まれていないセット)にあり、ソースからの距離が最小である頂点を見つけます。 アルゴリズム: Begin    function dijkstra() to find minimum distance:   &nb

  2. C++を使用して独自のsizeof演算子を実装する

    独自のsizeof()演算子を実装できるオプションがあります。演算子sizeof()は単項演算子であり、任意のタイプのデータのサイズを計算するために使用されます。 #defineディレクティブを使用して、sizeof()演算子とまったく同じように機能する独自のsizeof()演算子を実装できます。 独自のsizeof()演算子を実装するための構文は次のとおりです #define Any_name(object) (char *)(&object+1) - (char *)(&object) ここで Any_name −独自のsizeof()演算子に付ける名前。 これ