我是靠谱客的博主 清爽裙子,这篇文章主要介绍关于“使用rand()产生的随机数每次得到的结果相同”的问题,现在分享给大家,希望可以做个参考。

之前使用rand()产生随机数出现了一个怪问题,一直没能理解
初次出现的随机数数列是1111 5556 3543 6434 3245
再次运行,产生的结果仍然是1111 5556 3543 6434 3245
再运行,仍然是1111 5556 3543 6434 3245
…………..
由于是初学,完全不知道这是怎么回事,最近把这个”怪问题“解决了


具体可参照该程序看

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
#include <stdio.h> #include <stdlib.h> int main() { unsigned int seed; /*申明初始化器的种子,注意是unsigned int 型的*/ int k; printf("Enter a positive integer seed value: n"); scanf("%u",&seed); //srand(seed); printf("Random Numbers are:n"); for(k = 1; k <= 10; k++) { printf("%i",rand()); printf("n"); } return 0; }

实际上,rand是一个伪随机数发生器,这意味着可以预测数字的实际顺序,但这些数字在可能的取值范围内均匀的分布(计算机不具有自发性)
那么出现文章开头的情况就是典型的“伪”字的体现。

在C PRIMER PLUS中用这样一个程序来进行解释的

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
#include <stdio.h> extern int rand0(void); int main(void) { int count; for(count=0;count<5;count++) { printf("%dn",rand0()); } return 0; } static unsigned long int next = 1; int rand0(void) { next = next * 1103515245 +12345; return (unsigned int)(next/65536)%32768; }

通过程序中的计算式就可以知道具体的实现过程,
函数使用种子来产生一个新数,而这个新数有称为新的种子。接着,这个新种子被用来产生一个更新的种子,以此类推。
但是每次运行主程序时,都从同一个种子值开始,所以得到的结果是一样的。

于是给出第二个程序,用来解决出事种子值相同时,后续产生的数字相同的问题

复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#include <stdio.h> extern int rand1(void); extern void srand1(unsigned int seed); int main(void) { int count; unsigned seed; printf("Enter seedn"); while (scanf("%u",&seed)==1) { srand1(seed);//重置种子 for(count=0;count<5;count++) printf("%dn",rand1()); printf("Enter next seedn"); } return 0; } static unsigned long int next = 1; int rand1(void) { next = next * 1103515245 +12345; return (unsigned int)(next/65536)%32768; } void srand1(unsigned int seed) { next = seed; }

最后

以上就是清爽裙子最近收集整理的关于关于“使用rand()产生的随机数每次得到的结果相同”的问题的全部内容,更多相关关于“使用rand()产生内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(54)

评论列表共有 0 条评论

立即
投稿
返回
顶部