rand

疑似乱数を生成します。 より多くをプログラムで実行する、この関数のセキュリティが強化されたバージョンについては、「rand_s」を参照してください。 rand によって生成される数値は、暗号化によって保護されていません。 暗号化されより安全な乱数生成を行うには、rand_s または <random> の C++ 標準ライブラリで宣言された関数を使用します。

構文

int rand(void);

戻り値

rand は、上述のように疑似乱数を返します。 エラーの戻り値はありません。

解説

rand 関数は、0 から RAND_MAX (32767) までの範囲の整数の擬似乱数を返します。 rand を呼び出す前に、srand 関数を使用して擬似乱数ジェネレーターにシードを設定します。

rand 関数は既知のシーケンスを生成するため、暗号関数としての使用には適していません。 暗号化されより安全な乱数生成を行うには、rand_s または <random> の C++ 標準ライブラリで宣言された関数を使用します。

既定では、この関数のグローバル状態の適用対象は、アプリケーションになります。 この動作を変更するには、「CRT のグローバル状態」を参照してください

必要条件

ルーチンによって返される値 必須ヘッダー
rand <stdlib.h>

互換性の詳細については、「 Compatibility」を参照してください。

// crt_rand.c
// This program seeds the random-number generator
// with a fixed seed, then exercises the rand function
// to demonstrate generating random numbers, and
// random numbers in a specified range.

#include <stdlib.h> // rand(), srand()
#include <stdio.h> // printf()

void SimpleRandDemo(int n)
{
    // Print n random numbers.
    for (int i = 0; i < n; i++)
    {
        printf("  %6d\n", rand());
    }
}

void RangedRandDemo(int range_min, int range_max, int n)
{
    // Generate random numbers in the interval [range_min, range_max], inclusive.

    for (int i = 0; i < n; i++)
    {
        // Note: This method of generating random numbers in a range isn't suitable for
        // applications that require high quality random numbers.
        // rand() has a small output range [0,32767], making it unsuitable for
        // generating random numbers across a large range using the method below.
        // The approach below also may result in a non-uniform distribution.
        // More robust random number functionality is available in the C++ <random> header.
        // See https://learn.microsoft.com/cpp/standard-library/random
        int r = ((double)rand() / RAND_MAX) * (range_max - range_min) + range_min;
        printf("  %6d\n", r);
    }
}

int main(void)
{
    // Seed the random-number generator with a fixed seed so that
    // the numbers will be the same every time we run.
    srand(1792);

    printf("Simple random number demo ====\n\n");
    SimpleRandDemo(10);
    printf("\nRandom number in a range demo ====\n\n");
    RangedRandDemo(-100, 100, 100000);
}```

```Output
Simple random number demo ====

    5890
    1279
   19497
    1207
   11420
    3377
   15317
   29489
    9716
   23323

Random number in a range demo ====

     -82
     -46
      50
      77
     -47
      32
      76
     -13
     -58
      90

関連項目

数学と浮動小数点のサポート
srand
rand_s
C++ <random> ライブラリ