| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2470 人关注过本帖
标题:随机数的产生
只看楼主 加入收藏
无缘今生
Rank: 2
等 级:新手上路
威 望:3
帖 子:523
专家分:7
注 册:2007-6-25
结帖率:100%
收藏
 问题点数:0 回复次数:12 
随机数的产生
在网上搜索了N久,都是些大同小异的实现方法.要么有些根本就不行.

请各位来说说,究竟如何才能产生比较满意的随机数.
前提是: 不用与rand()类似的一些库函数.
搜索更多相关主题的帖子: 随机数 rand 搜索 函数 大同小异 
2007-11-24 20:48
VxWorks
Rank: 3Rank: 3
来 自:WindRiver
等 级:论坛游民
威 望:6
帖 子:859
专家分:68
注 册:2007-11-24
收藏
得分:0 
取当前系统时间做随即数种子,把这个种子转换为合适的数据类型x,然后通过一个函数y=f(x)算出映射y,这个y就是随即数。

 Donald.E.Knuth的那本<<The Art of Computer Programming>>中有一章是随即数算法的讨论。

我以前不能用标准库时遇到过和你一样的问题。
2007-11-24 22:08
无缘今生
Rank: 2
等 级:新手上路
威 望:3
帖 子:523
专家分:7
注 册:2007-6-25
收藏
得分:0 
再请教楼上:取得系统时间做随机数种子的方法是不是这样:
            srand(time(NULL));

时不再来!!!
2007-11-24 23:01
VxWorks
Rank: 3Rank: 3
来 自:WindRiver
等 级:论坛游民
威 望:6
帖 子:859
专家分:68
注 册:2007-11-24
收藏
得分:0 
我还以为你不能用标准库呢,既然可以何必要自己写rand函数?只要你把种子设置好了这个函数产生的伪随机数还是不错的。
程序代码:
// crt_rand.c
// This program seeds the random-number generator
// with the time, then displays 10 random integers.
//

#include <stdlib.h>
#include <stdio.h>
#include <time.h>

int main( void )
{
   int i;
   
   // Seed the random-number generator with current time so that
   // the numbers will be different every time we run.
   //
   srand( (unsigned)time( NULL ) );

   // Display 10 numbers.
   for( i = 0;   i < 10;i++ )
      printf( "  %6d\n", rand() );

  printf("\n");

  // Usually, you will want to generate a number in a specific range,
  // such as 0 to 100, like this:
  {
     int RANGE_MIN = 0;
     int RANGE_MAX = 100;
     for (i = 0;    i < 10; i++ )
      {
         int rand100 = (((double) rand() / 
                         (double) RAND_MAX) * RANGE_MAX + RANGE_MIN);
         printf( "  %6d\n", rand100);
      }
  }
   getchar();
   return 0;
}
2007-11-25 09:33
无缘今生
Rank: 2
等 级:新手上路
威 望:3
帖 子:523
专家分:7
注 册:2007-6-25
收藏
得分:0 
这个函数不错,可以满足要求。
但是,如果我想自己另写一个,采用什么算法比较好呢?
在网上找的那些什么同余法等等所产生的结果都不是很理想。

时不再来!!!
2007-11-26 11:59
yuanhong
Rank: 1
等 级:新手上路
帖 子:89
专家分:0
注 册:2006-4-2
收藏
得分:0 
原帖由 [bold][underline]无缘今生[/underline][/bold] 于 2007-11-24 23:01 发表 [url=http://bbs.][/url]
再请教楼上:取得系统时间做随机数种子的方法是不是这样:
            srand(time(NULL));

            srand(time(0))

2007-11-26 15:59
leeco
Rank: 4
等 级:贵宾
威 望:10
帖 子:1029
专家分:177
注 册:2007-5-10
收藏
得分:0 
原帖由 [bold][underline]无缘今生[/underline][/bold] 于 2007-11-26 11:59 发表 [url=http://bbs.][/url]
这个函数不错,可以满足要求。
但是,如果我想自己另写一个,采用什么算法比较好呢?
在网上找的那些什么同余法等等所产生的结果都不是很理想。 ...


你所谓的不理想是指什么。分布不理想?
2007-11-27 15:38
无缘今生
Rank: 2
等 级:新手上路
威 望:3
帖 子:523
专家分:7
注 册:2007-6-25
收藏
得分:0 
楼上说得对,所产生的各随机数的分布的确让人难以相信那是随机数.
给我的感觉就是:那只是经过变换的一组确定的数字!
个人愚见,请各位指正.

时不再来!!!
2007-11-28 13:34
忘记喧嚣
Rank: 1
等 级:新手上路
帖 子:146
专家分:0
注 册:2007-10-7
收藏
得分:0 
那你就 圆周率 随便取几为 就是随即数了
2007-11-28 22:33
StarWing83
Rank: 8Rank: 8
来 自:仙女座大星云
等 级:贵宾
威 望:19
帖 子:3951
专家分:748
注 册:2007-11-16
收藏
得分:0 
其实主要是开始的种子的选取和算法的选择~很早以前感兴趣研究过,不过没有深究~~

专心编程………
飞燕算法初级群:3996098
我的Blog
2007-12-19 01:20
快速回复:随机数的产生
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.017654 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved