知识分享 – 基础知识 | 每日一练(125)

基础知识练习

读者:我需要一个随机数生成器,怎么弄?

小林:标准 C 库函数就有一个: rand()。你系统上的实现可能并不完美, 但写一个更好的并不是一件容易的事。网上有许多这方面的包: 老的可靠的包有 r250, RANLIB 和 FSULTRA。

读者:每次执行程序, rand() 都返回相同顺序的数字,怎么解决?

小林:你可以调用 srand() 来初始化模拟随机数发生器的种子, 用的值可以是真正随机数或至少是个变量, 例如当前时间。

这儿有个例子:

#include <stdlib.h>

#include <time.h>

srand((unsigned int)time((time_t *)NULL));

不幸的是, 这个代码并不完美——其中, time() 返回的 time t 可能是浮点值,

转换到无符号整数时有可能上溢, 这造成不可移植。

在一个程序执行中多次调用 srand() 并不见得有帮助; 特别是不要为了试图取得 “真随机数” 而在每次调用 rand() 前都调用 srand()。

正文完