【发布时间】:2010-09-28 23:54:05
【问题描述】:
我正在尝试在 C 中生成 80 个字符的固定字符串的随机排列。令我沮丧的是,我正在使用的系统缺少 strfry()。我生成这个字符串的随机排列的最佳方法是什么?因为这将循环大约。 100,000 次,性能是个问题。
【问题讨论】:
我正在尝试在 C 中生成 80 个字符的固定字符串的随机排列。令我沮丧的是,我正在使用的系统缺少 strfry()。我生成这个字符串的随机排列的最佳方法是什么?因为这将循环大约。 100,000 次,性能是个问题。
【问题讨论】:
只需使用Google Code 发现的开源 GLIBC 实现即可。
char *
strfry (char *string)
{
static int init;
static struct random_data rdata;
size_t len, i;
if (!init)
{
static int state[8] = { 1, 2, 3, 4, 5, 6, 7, 8 };
rdata.state = NULL;
__initstate_r (time ((time_t *) NULL), state, 8, &rdata);
init = 1;
}
len = strlen (string);
for (i = 0; i < len; ++i)
{
int32_t j;
char c;
__random_r (&rdata, &j);
j %= len;
c = string[i];
string[i] = string[j];
string[j] = c;
}
return string;
}
您可能希望将 GLIBC 特定数据类型更改为更通用的类型。
这段代码使用Fisher-Yates shuffle,其实很容易自己实现,效率很高。
【讨论】:
创建一个 80 行的数组,将一个字符和一个随机数放入数组的每一行,然后根据随机数对数组进行排序。
从排序后的数组重建字符串。
【讨论】:
void gcry_randomize (unsigned char *buffer, size_t length, enum gcry_random_level level)
使用 level 定义的随机质量用长度随机字节填充缓冲区。
【讨论】: