C++中生成随机数:需要用到的函数,一个是rand(),该函数只返回一个伪随机数。生成随机数之前必须先调用srand()函数。

生成随机数

#include iostream;
#include ctime;
#include cstdlib; using namespace std; int main ()
{
int i,j; // 设置种子
srand( (unsigned)time( NULL ) ); /* 生成 10 个随机数 */
for( i = 0; i 10; i++ )
{
// 生成实际的随机数
j= rand();
cout "随机数: " j endl;
}
getchar();
return 0;
}



(1)说明

srand函数是随机数发生器的初始化函数。

(2)原型: class="marked">void srand(unsigned seed);

(3)用法:它需要提供一个种子,这个种子会对应一个随机数,如果使用相同的种子后面的rand()函数会出现一样的随机数。如:srand(1);直接使用 1 来初始化种子。不过为了防止随机数每次重复,常常使用系统时间来初始化,即使用 time 函数来获得系统时间,它的返回值为从 00:00:00 GMT, January 1, 1970 到现在所持续的秒数,然后将 time_t 型数据转化为(unsigned)型再传给 srand 函数,即: srand((unsigned) time(&t)); 还有一个经常用法,不需要定义time_t型t变量,即: srand((unsigned) time(NULL)); 直接传入一个空指针,因为你的程序中往往并不需要经过参数获得的t数据。

生成指定范围的随机数

第一种

#include iostream;
#include ctime;
#include cstdlib; using namespace std; int main ()
{
int i,j; // 设置种子
srand( (unsigned)time( NULL ) ); /* 生成 10 个随机数 */
for( i = 0; i 10; i++ )
{
// 生成实际的随机数
j= rand();
cout "随机数: " j % 100 endl;
}
getchar();
return 0;
}

或者可以在宏定义中顶一个random(int number)函数:

#include iostream;
#include ctime;
#include cstdlib;
#define random(x)(rand()%x)
using namespace std; int main ()
{
int i,j; // 设置种子
srand( (unsigned)time( NULL ) ); /* 生成 10 个随机数 */
for( i = 0; i 10; i++ )
{
// 生成实际的随机数
cout "随机数: " random(100) endl;
}
getchar();
return 0;
}

第2种

使用 rand() 和 srand() 产生指定范围内的随机整数的方法:“模除+加法”的方法。如要产生 [m,n] 范围内的随机数 num,可用:int num=rand()%(n-m+1)+m;(即rand()%[区间内数的个数]+[区间起点值])

例如:使用随机数来发红包:

#include iostream;
#include ctime;
#include cstdlib;
#include iomanip;
#include math.h; using namespace std; int main()
{
int i, number;
int best;//手气最佳
float total; cout "请输入红包金额:";
cin ;; total;
cout "请输入抢红包人数:";
cin ;; number;
/* 生成随机数 */
// 设置种子
srand((unsigned)time(NULL));
float a[1024];//保存每个人的随机数。最多支持1024个人抢红包。
float b[1024];//保存每个人获得的红包金额。
float suma = 0;//随机数总和。
float sumb = 0;//红包总和。
int max = 0;
for (i = 0; i number; i++)
{
// 生成实际的随机数
a[i] = rand() % 100; if (a[i] ; max){
max = a[i];
best = i;//获取手气最佳
}
suma += a[i];
} for (i = 0; i number - 1; i++)
{
b[i] = a[i] / suma * total;//按照随机数计算每个人实际获得的金额
sumb += round(b[i] * 100) / 100.0;//将红包金额保留两位小数
//输出信息
cout "第" setiosflags(ios::right) setw(3) i + 1
"个人的红包是:" setiosflags(ios::right) setw(6)
setiosflags(ios::fixed) setprecision(2)
round(b[i] * 100) / 100.0 ;
if (best == i){
cout "(手气最佳)" endl;
}
else { cout endl;
}
}
//最后一人的红包金额等于总金额减去前面的金额。
cout "第" setiosflags(ios::right)
setw(3) number "个人的红包是:"
setiosflags(ios::right) setw(6) setiosflags(ios::fixed)
setprecision(2) round((total - sumb) * 100) / 100.0;
if (best == number - 1){
cout "(手气最佳)" endl;
}
else { cout endl;
} system("pause");
return 0;
}

说明:

1、setprecision(n)与setiosflags(ios::fixed)

setprecision(n)与setiosflags(ios::fixed)合用,可以控制小数点右边的数字个数。

2、setw(3)

setw(n) 设域宽为n个字符这个控制符的意思是保证输出宽度为n。

如:coutsetw(3)1setw(3)10setw(3)100;

输出结果为1 10100 (默认是右对齐)

当输出长度大于3时(1000),setw(3)不起作用

  • setioflags(ios::fixed) 固定的浮点显示
  • setioflags(ios::scientific) 指数表示
  • setiosflags(ios::left) 左对齐
  • setiosflags(ios::right) 右对齐
  • setiosflags(ios::skipws 忽略前导空白
  • setiosflags(ios::uppercase) 16进制数大写输出
  • setiosflags(ios::lowercase) 16进制小写输出
  • setiosflags(ios::showpoint) 强制显示小数点
  • setiosflags(ios::showpos) 强制显示符号

例如:

  • coutsetiosflags(ios::fixed)setiosflags(ios::right)setprecision(2):输出一个右对齐的小数点后两位的浮点数。
  • setprecision(n):控制输出流显示浮点数的数字个数。
  • setiosflags(ios::fixed):用定点方式表示实数。
  • iso::right :在指定区域内右对齐输出

C++:随机数生成的更多相关文章

  1. 史上最全的java随机数生成算法分享(转)

    这篇文章主要介绍了史上最全的java随机数生成算法,我分享一个最全的随机数的生成算法,最代码的找回密码的随机数就是用的这个方法 String password = RandomUtil.generat ...

  2. org.apache.commons.lang3 的随机数生成

    apache org.apache.commons.lang3 的随机数生成工具,方便使用. String a12 = RandomStringUtils.random(4, "012345 ...

  3. js控制随机数生成概率代码实例

    基本思路:把Math.random()js随机数生成的数看着百分比,然后定义每个整数值取值范围. 具体内容如下,供大家参考 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 ...

  4. MATLAB与C语言对比实例:随机数生成

    MATLAB与C语言对比实例:随机数生成 作者:凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ 一.整型随机数生成函数 1.C语言程序 int intrand ...

  5. linux随机数生成

    随机数多应用在密码的随机生成 #随机数生成 $RANDOM (1-32767) 11.内部系统变量($RANDOM) 1-32767 22. awk 'BEGIN{srand();print rand ...

  6. 常用分布随机数生成及JS类函数开发和运用

    (2017-02-15 银河统计) 随机数生成是运用蒙特卡洛或统计随机模拟仿真方法的前提.本文在银河统计Web Service接口基础上,编制JS类函数生成常用分布随机数,为在网页中实现模拟仿真项目提 ...

  7. numpy.random随机数生成

    seed 确定随机数生成器的种子 permutation 返回一个序列的随机排列或返回一个随机排列的返回 shuffle 对一个序列就地随机乱序 rand 产生均匀分布的样本值 randint 从给定 ...

  8. Codeforces Round #538 (Div. 2) E 随机数生成

    https://codeforces.com/contest/1114/problem/E 题意 交互题,需要去猜一个乱序的等差数列的首项和公差,你能问两种问题 1. 数列中有没有数比x大 2. 数列 ...

  9. JS实现随机数生成算法示例代码

    JS实现随机数生成算法的方法有很多,本文为大家介绍一个比较不错的方法. 1, var MT = []; var index = 0; function initialize_generator(see ...

  10. 实用的随机数生成类Random:测试(随机产生100个不重复的正整数)

    实用的随机数生成类Random:测试(使用Random类随机生成100个不重复的正整数) 一.之前我们使用随机数用的是Math类的random()方法: tips: 产生随机数(0~9中任意整数)的方 ...

随机推荐

  1. 斯坦福大学推出线性前沿LLM技术,训练模型成本仅为20美元

    序言:当前基于 Transformer 架构的大语言模型人工智能技术,由于投入大.成本高.人才需求苛刻,导致许多企业望而却步.动辄几千万甚至上亿的成本,现实中有几家企业能够承担?真正具有竞争力的技术应 ...

  2. 鸿蒙NEXT开发案例:二维码的生成与识别

    [引言] 在本篇文章中,我们将探讨如何在鸿蒙NEXT平台上实现二维码的生成与识别功能.通过使用ArkUI组件库和相关的媒体库,我们将创建一个简单的应用程序,用户可以生成二维码并扫描识别. [环境准备] ...

  3. jQuery.validator验证无效的可能原因

    最近用jQuery.validator做表单的前端验证,却发现验证规则都无效.最后发现以下原因会导致校验无效 1.jquery.min.js重复引用. 2.js中有bug存在. 3.<input ...

  4. 如何使用建造者模式(Builder Pattern)创建不可变类

    本文由 ImportNew - 唐小娟 翻译自 Journaldev.如需转载本文,请先参见文章末尾处的转载要求. ImportNew注:如果你也对Java技术翻译分享感兴趣,欢迎加入我们的 Java ...

  5. 面向 Java 开发人员的 Scala 指南: 构建计算器,第 1 部分

    Scala 的 case 类和模式匹配 Ted Neward, 主管, Neward & Associates 简介: 特定于领域的语言已经成为一个热门话题:很多函数性语言之所以受欢迎,主要是 ...

  6. Java深度历险(九)——Java安全

    安全性是Java应用程序的非功能性需求的重要组成部分,如同其它的非功能性需求一样,安全性很容易被开发人员所忽略.当然,对于Java EE的开发人员来说,安全性的话题可能没那么陌生,用户认证和授权可能是 ...

  7. vue在组件中实现双向绑定

    父组件中的一个变量和子组件的input框实现双向绑定,就要用到下面的方法: 父组件: <script> import CustomInput from './CustomInput.vue ...

  8. 预热篇2:从RNN到Transformmer

    下面是整理的一个思维导图 2010年Mikolov提出了RNN网络,RNN网络存在长距离依赖(梯度消失),计算效率(RNN 难以并行)两个问题 2017年Transformmer网络结构问世,Tran ...

  9. 07C++选择结构(1)

    一.基础知识 1.关系运算符 因为我们要对条件进行判断,必然会用到关系运算符: 名称 大于 大于等于 小于 小于等于 等于 不等于 符号 > >= < <= == != 关系表 ...

  10. 升级到 .NET Core 3.1

    微软升级的频率有点快,转眼 .NET Core 升级到 3.1 版了,这是一个长期支持版本,意味着 .NET Core 正式进入成熟期. 不过,对于开发人员来说,你的项目又需要迁移了. 升级项目文件 ...