C++常见获取随机数的方法小结

 更新时间:2018年05月07日 08:47:01   作者:Wayne-Zhu  
这篇文章主要介绍了C++常见获取随机数的方法,结合实例形式总结分析了C++获取随机数的几种常见方法与相关操作注意事项,需要的朋友可以参考下

本文实例讲述了C++常见获取随机数的方法。分享给大家供大家参考,具体如下:

方法一:

使用 rand 函数可以获取,如下。

#include<iostream>
#include<ctime>
using namespace std;
int main()
{
  for (int i = 0; i < 10; i++)
  cout << rand() << endl;
  return 0;
}

随机数大小是在0到RAND_MAX,值为2147483647,它是在stdlib中定义的,如果我们希望在某个范围内,可以使用 % 结合 / 来实现。

但是不难发现,这里获得的随机数是唯一确定的,而不是变化的。所以,如果我们希望获得变化的随机数,可以使用下面的方法。

方法二:

既然使用rand函数无法获取到变化的随机数,这里就可以使用srand来实现了。

#include<iostream>
#include<ctime>
using namespace std;
int main()
{
  srand(time(0));
  for (int i = 0; i < 1000; i++)
  cout << rand() << endl;
  return 0;
}

这里,我们需要引入ctime库,其中time(0)是获取从1970年开始的时间(单位:s),然后再获取rand(),这时的rand就是随机变化得了。 如下:

但这里获取的值是不确定的,而如果我们希望获得在某一范围内的值呢,也很简单,如下所示:

#include<iostream>
#include<ctime>
using namespace std;
int main()
{
  srand(time(0));
  for (int i = 0; i < 100; i++)
  cout << rand() % 100 << endl;
  return 0;
}

如上,使用求余数的方法,我们可以获得0 - 100之间的值。

而如果我们希望得到0 -  1之间的数呢? 如下所示:

#include<iostream>
#include<ctime>
using namespace std;
int main()
{
  srand(time(0));
  for (int i = 0; i < 100; i++)
    cout << (rand() % 10) * 0.1 << endl;
  return 0;
}

而我们希望得到-1 到 1 之间的数呢?

#include<iostream>
#include<ctime>
using namespace std;
int main()
{
  srand(time(0));
  for (int i = 0; i < 100; i++)
   if (i % 2 == 0)
    cout << (rand() % 10) * 0.1 << endl;
   else 
    cout << (rand() % 10) * -0.1 << endl;
  return 0;
}

上面的程序虽然可以得到正随机数和负随机数,但是是交替出现的,还是不够随机,所以我们可以采用下面的方式:

#include<iostream>
#include<ctime>
using namespace std;
int main()
{
  srand(time(0));
  double a;
  for (int i = 0; i < 100; i++)
  if (rand() % 10 > 0.4)
  {
    cout << (rand() % 10) * 0.1 << endl;
  }
  else
  {
    a = (rand() % 10) * -0.1;
    if (a == -0.0)
    {
      cout << 0 << endl;
    }
    else
    {
      cout << a << endl;
    }
  }
  return 0;
}

这样,我们就可以得到真正的随机数了,后面使用 a == -0.0 判断是为了防止输出 -0 的情况。 最终结果如下:

PS:这里再提供几款相关工具供大家参考使用:

在线随机数生成工具:
http://tools.jb51.net/aideddesign/rnd_num

在线随机生成个人信息数据工具:
http://tools.jb51.net/aideddesign/rnd_userinfo

在线随机字符/随机密码生成工具:
http://tools.jb51.net/aideddesign/rnd_password

在线随机数字/字符串生成工具:
http://tools.jb51.net/aideddesign/suijishu

希望本文所述对大家C++程序设计有所帮助。

相关文章

  • 华为机试题之统计单词个数实例代码

    华为机试题之统计单词个数实例代码

    这篇文章主要介绍了华为机试题之统计单词个数实例代码的相关资料,需要的朋友可以参考下
    2017-05-05
  • 浅谈C语言结构体

    浅谈C语言结构体

    本文主要介绍C语言 结构体的知识,学习C语言肯定需要学习结构体,这里详细说明了结构体并附示例代码,供大家参考学习,有需要的小伙伴可以参考下
    2021-10-10
  • c++ 实现KMP算法

    c++ 实现KMP算法

    这篇文章主要介绍了c++ 实现KMP算法的示例,帮助大家更好的理解和学习c++,感兴趣的朋友可以了解下
    2020-10-10
  • C++数据结构之红黑树的实现

    C++数据结构之红黑树的实现

    红黑树在表意上就是一棵每个节点带有颜色的二叉搜索树,并通过对节点颜色的控制,使该二叉搜索树达到尽量平衡的状态。本文主要为大家介绍了C++中红黑树的原理及实现,需要的可以参考一下
    2022-08-08
  • C++实现图的遍历算法(DFS,BFS)的示例代码

    C++实现图的遍历算法(DFS,BFS)的示例代码

    本文给大家带来的是图遍历的算法,DFS(深度优先遍历),BFS(广度优先遍历)。这两个算法是比较重要和常用的算法,但是在图中的实现只是最基本的操作,快跟随小编一起学习一下吧
    2022-07-07
  • 深入了解C++优先队列(priority_queue)的使用方法

    深入了解C++优先队列(priority_queue)的使用方法

    在计算机科学中,优先队列是一种抽象数据类型,它与队列相似,但是每个元素都有一个相关的优先级。C++中的优先队列是一个容器适配器(container adapter),它提供了一种在元素之间维护优先级的方法。本文带你深入了解C++优先队列的使用方法,需要的可以参考下
    2023-05-05
  • OpenCV实现乱序碎片复原

    OpenCV实现乱序碎片复原

    这篇文章主要介绍了通过OpenCV 直方图相似度对比,实现将4张打乱顺序的碎片拼接复原并展示原图。文中的示例代码讲解详细,需要的朋友可以学习一下
    2021-12-12
  • c++编译使用log4cplus的详细步骤

    c++编译使用log4cplus的详细步骤

    C++很强大,但是仍然有很多不尽如人意的地方,比如打印日志方面就没有java的log4j那种信手拈来,自然而然地东西,今天我们说一说一个很强大地日志库log4cplus在c++项目中地使用,感兴趣的朋友一起看看吧
    2023-10-10
  • 如何使用VC库函数中的快速排序函数

    如何使用VC库函数中的快速排序函数

    下面呢,小编就为大家介绍一下VC中库函数qsort()的用法。需要的朋友可以过来参考下
    2013-09-09
  • C++实现校园运动会报名系统

    C++实现校园运动会报名系统

    这篇文章主要为大家详细介绍了C++实现校园运动会报名系统,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-10-10

最新评论