我主要是一个Java头,我想要一种方法来生成0到74之间的伪随机数。在Java中,我会使用这种方法:

Random.nextInt(74)

我对讨论种子或真正的随机性不感兴趣,我只关心如何在Objective-C中完成相同的任务。我搜索了谷歌,似乎有很多不同的和相互矛盾的信息。


当前回答

这会给你一个0到47之间的浮点数

float low_bound = 0;      
float high_bound = 47;
float rndValue = (((float)arc4random()/0x100000000)*(high_bound-low_bound)+low_bound);

或者只是简单的

float rndValue = (((float)arc4random()/0x100000000)*47);

下限和上限也可以是负的。下面的示例代码给出了一个介于-35.76和+12.09之间的随机数

float low_bound = -35.76;      
float high_bound = 12.09;
float rndValue = (((float)arc4random()/0x100000000)*(high_bound-low_bound)+low_bound);

将结果转换为整数值:

int intRndValue = (int)(rndValue + 0.5);

其他回答

//下面的例子将生成一个0到73之间的数字。

int value;
value = (arc4random() % 74);
NSLog(@"random number: %i ", value);

//In order to generate 1 to 73, do the following:
int value1;
value1 = (arc4random() % 73) + 1;
NSLog(@"random number step 2: %i ", value1);

输出:

随机数:72 随机数字步骤2:52

和C一样

#include <time.h>
#include <stdlib.h>
...
srand(time(NULL));
int r = rand() % 74;

(假设您的意思是包括0但不包括74,这就是您的Java示例所做的)

编辑:请随意用random()或arc4random()代替rand()(正如其他人指出的那样,这非常糟糕)。

根据rand(3)的手册页,rand函数家族已被随机(3)淘汰。这是因为rand()的下12位经过循环模式。要获得随机数,只需通过使用unsigned种子调用srandom()来生成生成器,然后调用random()。因此,与上面的代码等价的是

#import <stdlib.h>
#import <time.h>

srandom(time(NULL));
random() % 74;

你只需要在你的程序中调用srandom()一次,除非你想改变你的种子。虽然您说过不想讨论真正的随机值,但rand()是一个非常糟糕的随机数生成器,random()仍然受到模偏置的影响,因为它将生成一个介于0和RAND_MAX之间的数字。例如,如果RAND_MAX是3,而你想要一个0到2之间的随机数,你得到0的可能性是得到1或2的两倍。

我想我可以添加一个我在许多项目中使用的方法。

- (NSInteger)randomValueBetween:(NSInteger)min and:(NSInteger)max {
    return (NSInteger)(min + arc4random_uniform(max - min + 1));
}

如果我最终在许多文件中使用它,我通常声明一个宏为

#define RAND_FROM_TO(min, max) (min + arc4random_uniform(max - min + 1))

E.g.

NSInteger myInteger = RAND_FROM_TO(0, 74) // 0, 1, 2,..., 73, 74

注意:仅适用于iOS 4.3/OS X v10.7 (Lion)及更高版本

您应该使用arc4random_uniform()函数。它使用了一种高级算法来标记。你甚至不需要设置种子。

#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))