文档章节

洗牌算法

AndyZhouX
 AndyZhouX
发布于 2017/08/05 10:46
字数 187
阅读 8
收藏 0

        srand(unsigned seed)通过参数seed改变系统提供的种子值,从而可以使得每次调用rand函数生成的伪随机数序列不同,从而实现真正意义上的“随机”。srand和rand()配合使用产生伪随机数序列。

#include <stdlib.h>
#include <ctime>

void XiPai(int array[], int length)
{
    int index = 0;
    
    int nTemp = 0;

    if (NULL == array || 0 == length)
        return;

    srand(unsigned(time(NULL)));   //获取time函数返回的值,每次更改随机数种子,初始化随机数发生器

    //发牌的时候对于已经分配的数据不再修改
    for (int i = 0; i < length; i++)
    {
        //产生随机索引
        index = i + rand() % (length - i);

        
        //数据[新产生的索引] = 数据[原来的索引];
        nTemp = array[i];
        array[i] = array[index];
        array[index] = nTemp;
    }
}

© 著作权归作者所有

共有 人打赏支持
AndyZhouX
粉丝 1
博文 140
码字总数 96828
作品 0
深圳
程序员

暂无文章

angular 解决其他电脑不能访问的问题。

ng serve --host 0.0.0.0 --disable-host-check

miaojiangmin
今天
1
0
优酷视频文件怎么转换格式

  以前在优酷上下载视频都只是在手机上观看,但随着科技的发展,对于视频的要求也逐渐增多,不再只是观看视频那么简单,在精彩的部分还会将其单独分割出来,然后进行视频剪辑,可以做出我们...

萤火的萤火
今天
0
0
数据结构:散列

在一个数据结构中查找key元素,用顺序查找、二分查找都需要经过一系列关键之比较才能查找到结果,平均查找长度与数据量有关,元素越多比较次数就越多。 如果根据元素的关键字就能知道元素的存...

京一
今天
1
0
Apache RocketMQ 正式开源分布式事务消息

近日,Apache RocketMQ 社区正式发布4.3版本。此次发布不仅包括提升性能,减少内存使用等原有特性增强,还修复了部分社区提出的若干问题,更重要的是该版本开源了社区最为关心的分布式事务消...

阿里云云栖社区
今天
33
0
使用JavaScript和MQTT开发物联网应用

如果说Java和C#哪个是最好的开发语言,无疑会挑起程序员之间的相互怒怼,那如果说JavaScript是动态性最好的语言,相信大家都不会有太大的争议。随着越来越多的硬件平台和开发板开始支持JavaS...

少年不搬砖老大徒伤悲
今天
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部