构造法生成随机数

sjd163 2014-02-06 03:10:52
构造法生成随机数
  顾名思义构造法就是要预先设定好数组的成员,一般都希望数组成员的分布是均匀的,所以要包括所有元素,并且元素个数相等。就现在的文件体系,最小单位是字节,一个字节等于8位二进制数。数组元素有256个字节,字节数值从 0到 255。这样构造的数组长度应该是256的倍数。
  构造好的数组要想过度到随机数组,对数组进行随机排序即可。一般用随机函数来完成随机排序这里仅举一例:为作用到每个元素,采用所有元素依序号循环的方式,在循环中你可以用随机函数生成一个在数组长度内的数作为交换序号,用此序号的元素和当前的循环序号的元素作数值交换,依次向下则所有元素都被交换了。数组原来是分布均匀的规律性数组,排序后将成为无规律的乱码数组。
  新生成数组除了分布均匀,并且是没有周期的,这点虽然不好证明但是有热力学第二定律作理论上的支持,一个过程在多种因素作用下,只能从有序化向无序化发展,而不能从无序化向有序化发展,所以作随机排序后数组是越来越无序了。这在自然界也是不争的事实,例如将几种颜色不同的沙子放在一起搅动,颜色将越来越混合,一旦混合后再没有靠搅合将各色沙子分离出来的可能。又如将墨水滴入水中,在水中从新聚成墨滴的可能是近乎零概率事件。
  如果构造的初始数组也是乱码数据,将更有利于数组向更乱的方向发展。
  形成数据和数组的初始状态有关,和随机函数有关,和随机函数的种子有关,和随机序号算式
有关,改动这些数值可以得到不同的结果数组。
  如果适当的调整生成随机序号的算式充分利用现有的随机资源,你甚至可以不用随机函数参与而得到随机数组。
  这样生成的随机数能保证数值的随机性和分布均匀。方法是灵活的如果随机性要求较高,你可以进行检测,或者对数组进行多次随机排序。
...全文
96 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
schlafenhamster 2014-02-06
  • 打赏
  • 举报
回复
"一个过程在多种因素作用下,只能从有序化向无序化发展,而不能从无序化向有序化发展,所以作随机排序后数组是越来越无序了" [color=#FF0000]大数定理 结果是高斯分布 , 不是均匀分布.[/color]

16,471

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧