私は主に Java を使っており、0 から 74 までの疑似乱数を生成する方法を探しています。Java では次のメソッドを使用します。
Random.nextInt(74)
私はシードや真のランダム性についての議論には興味がありません。Objective-C で同じタスクをどうやって実現するかということに興味があります。Google でいろいろ調べてみましたが、さまざまな矛盾した情報がたくさんあるようです。
ベストアンサー1
関数を使用する必要がありますarc4random_uniform()
。これは、より優れたアルゴリズムを使用しますrand
。シードを設定する必要さえありません。
#include <stdlib.h>
// ...
// ...
int r = arc4random_uniform(74);
マニュアルarc4random
ページ:
NAME arc4random, arc4random_stir, arc4random_addrandom -- arc4 random number generator LIBRARY Standard C Library (libc, -lc) SYNOPSIS #include <stdlib.h> u_int32_t arc4random(void); void arc4random_stir(void); void arc4random_addrandom(unsigned char *dat, int datlen); DESCRIPTION The arc4random() function uses the key stream generator employed by the arc4 cipher, which uses 8*8 8 bit S-Boxes. The S-Boxes can be in about (2**1700) states. The arc4random() function returns pseudo- random numbers in the range of 0 to (2**32)-1, and therefore has twice the range of rand(3) and random(3). The arc4random_stir() function reads data from /dev/urandom and uses it to permute the S-Boxes via arc4random_addrandom(). There is no need to call arc4random_stir() before using arc4random(), since arc4random() automatically initializes itself. EXAMPLES The following produces a drop-in replacement for the traditional rand() and random() functions using arc4random(): #define foo4random() (arc4random() % ((unsigned)RAND_MAX + 1))