C++:随机数生成
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++:随机数生成的更多相关文章
- 史上最全的java随机数生成算法分享(转)
这篇文章主要介绍了史上最全的java随机数生成算法,我分享一个最全的随机数的生成算法,最代码的找回密码的随机数就是用的这个方法 String password = RandomUtil.generat ...
- org.apache.commons.lang3 的随机数生成
apache org.apache.commons.lang3 的随机数生成工具,方便使用. String a12 = RandomStringUtils.random(4, "012345 ...
- js控制随机数生成概率代码实例
基本思路:把Math.random()js随机数生成的数看着百分比,然后定义每个整数值取值范围. 具体内容如下,供大家参考 ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 ...
- MATLAB与C语言对比实例:随机数生成
MATLAB与C语言对比实例:随机数生成 作者:凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ 一.整型随机数生成函数 1.C语言程序 int intrand ...
- linux随机数生成
随机数多应用在密码的随机生成 #随机数生成 $RANDOM (1-32767) 11.内部系统变量($RANDOM) 1-32767 22. awk 'BEGIN{srand();print rand ...
- 常用分布随机数生成及JS类函数开发和运用
(2017-02-15 银河统计) 随机数生成是运用蒙特卡洛或统计随机模拟仿真方法的前提.本文在银河统计Web Service接口基础上,编制JS类函数生成常用分布随机数,为在网页中实现模拟仿真项目提 ...
- numpy.random随机数生成
seed 确定随机数生成器的种子 permutation 返回一个序列的随机排列或返回一个随机排列的返回 shuffle 对一个序列就地随机乱序 rand 产生均匀分布的样本值 randint 从给定 ...
- Codeforces Round #538 (Div. 2) E 随机数生成
https://codeforces.com/contest/1114/problem/E 题意 交互题,需要去猜一个乱序的等差数列的首项和公差,你能问两种问题 1. 数列中有没有数比x大 2. 数列 ...
- JS实现随机数生成算法示例代码
JS实现随机数生成算法的方法有很多,本文为大家介绍一个比较不错的方法. 1, var MT = []; var index = 0; function initialize_generator(see ...
- 实用的随机数生成类Random:测试(随机产生100个不重复的正整数)
实用的随机数生成类Random:测试(使用Random类随机生成100个不重复的正整数) 一.之前我们使用随机数用的是Math类的random()方法: tips: 产生随机数(0~9中任意整数)的方 ...
随机推荐
- 2024 BUPT Programming Contest F
简要题意 多测,给定一个 \(n \times n\) 矩阵,矩阵中的每一个元素的计算方式如下: 矩阵的行和列唯一决定两个整数对 \((a, b)\),矩阵第 \(a(0 \le a < n)\ ...
- 【一步步开发AI运动小程序】三、运动识别处理流程
随着人工智能技术的不断发展,阿里体育等IT大厂,推出的"乐动力"."天天跳绳"AI运动APP,让云上运动会.线上运动会.健身打卡.AI体育指导等概念空前火热.那 ...
- MySQL创新版9.1.0于2024年10月15日正式发布-新功能特性先睹为快[译]
这个十月发布的版本是MySQL宣布转向新的LTS/Innovation发布模式后的第三个长期支持(LTS)版本和第二个创新(Innovation)版本.更多细节请参见MySQL发布:创新和长期支持.在 ...
- Solr 学习(5) —- Solr查询语法和参数
1.查询地址 建立好solr的索引后,可以通过管理界面进行查询.http://127.0.0.1:8983/solr/admin/form.jsp 要尝试多个查询方法的话,可以进入full inter ...
- 移动端自动化之Autox.js
github: https://github.com/kkevsekk1/AutoX 官方文档:http://doc.autoxjs.com/ 1. 安装vscode的扩展插件 如果之前有使用 aut ...
- laravel框架之ORM操作
Laravel 支持原生的 SQL 查询.流畅的查询构造器 和 Eloquent ORM 三种查询方式: 流畅的查询构造器(简称DB),它是为创建和运行数据库查询提供的一个接口,支持大部分数据库操作, ...
- 使用SharpCompress压缩,tar.gz
之前我们介绍了如何用SharpZipLib来打.tar.gz压缩包. 但是这个压缩软件有两个问题,一是代码比较多,压缩起来没有那么方便:二是压缩的.tar.gz在linux上解压时会有警告,需要跳过这 ...
- 如何优雅地在Django项目里生成不重复的ID?
前言 本来标题是想叫"生成不重复的四位数"的,不过单纯数字有点局限,推广一下变成不重复 ID 吧~ 这个功能是在做下面图片里这个小项目时遇到的,有点像微信的面对面建群,生成一个随机 ...
- vtkCellLocator IntersectWithLine 返回不是最近的交点
vtkCellLocator IntersectWithLine 有一个重载函数(下面),返回不是最近的交点,因为到交点的距离没有比较,就直接覆盖了.不知道原本是否就是这样.可以用其他重载代替. in ...
- RabbitMQ快速入门 整合 SpringBoot
RabbitMQ快速入门 整合 SpringBoot 概述 大多应用中,可通过消息服务中间件来提升系统异步通信.扩展解耦能力.流量削峰 消息服务中两个重要概念: 消息代理(`message broke ...