免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 2465 | 回复: 10
打印 上一主题 下一主题

随机数的问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2008-08-29 17:11 |只看该作者 |倒序浏览
使用以下代码生成随机数,结果100个随机数都是一样的,应该是种子没有发生改变,
如何让这样的随机数也随即起来?请教高手指点,:)


#include <iostream>
using namespace std;

int main() {
  for (int i=0; i<100; i++) {
    // initialize random seed:
    srand(time(NULL));

    // generate secret number:
    int radChoice = rand();

    cout << radChoice << endl;
  }

  return 0;
}

论坛徽章:
0
2 [报告]
发表于 2008-08-29 17:12 |只看该作者
把srand放到循环外面来

论坛徽章:
0
3 [报告]
发表于 2008-08-29 17:15 |只看该作者

回复 #2 cugb_cat 的帖子

谢谢,

论坛徽章:
0
4 [报告]
发表于 2008-08-29 17:29 |只看该作者
一般使用系统当前时间作为种子

论坛徽章:
0
5 [报告]
发表于 2008-08-29 17:57 |只看该作者
主要是循环太快种子没变
楼主在循环中加个sleep停顿一下看看

论坛徽章:
0
6 [报告]
发表于 2008-08-29 18:08 |只看该作者
原帖由 gawk 于 2008-8-29 01:57 发表
主要是循环太快种子没变
楼主在循环中加个sleep停顿一下看看


应该是种子只用在最开始设一次。

论坛徽章:
0
7 [报告]
发表于 2008-08-29 18:14 |只看该作者

  1. #include <iostream>
  2. using namespace std;

  3. int main() {
  4.     srand(time(NULL));
  5.   for (int i=0; i<100; i++) {
  6.     // initialize random seed:
  7.     //srand(time(NULL));

  8.     // generate secret number:
  9.     int radChoice = rand();

  10.     cout << radChoice << endl;
  11.   }

  12.   return 0;
  13. }
复制代码

论坛徽章:
0
8 [报告]
发表于 2008-08-31 00:25 |只看该作者
原帖由 emacsnw 于 2008-8-29 18:08 发表


应该是种子只用在最开始设一次。

试试这个,种子也可以多弄几次

  1. #include <iostream>
  2. using namespace std;

  3. int main() {
  4.   for (int i=0; i<100; i++) {
  5.     // initialize random seed:
  6.     srand(time(NULL));

  7.     // generate secret number:
  8.     int radChoice = rand();
  9.         sleep(1);
  10.     cout << radChoice << endl;
  11.   }

  12.   return 0;
  13. }
复制代码

这是我的一些打印
-bash-3.00$ a.out
18243
2313
19152
3222
20060
4131
20969
5039
21878
5948
22786
6856
23695

论坛徽章:
0
9 [报告]
发表于 2008-08-31 04:32 |只看该作者
原帖由 gawk 于 2008-8-30 08:25 发表

试试这个,种子也可以多弄几次

#include
using namespace std;

int main() {
  for (int i=0; i


虽然都是伪随机,这样子得到的随机数统计上分布不太好,不是太均匀。不信可以做个Kai^2测试看看。

论坛徽章:
0
10 [报告]
发表于 2008-08-31 08:07 |只看该作者
原帖由 emacsnw 于 2008-8-31 04:32 发表


虽然都是伪随机,这样子得到的随机数统计上分布不太好,不是太均匀。不信可以做个Kai^2测试看看。

的确不好,看看生成的是一大一下,很有规律,呵呵
我记得k&r的书上好像有srand和rand的算法
看看先
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP