C++如何产生随机数

转载自**

https://www.cnblogs.com/ql698214/p/5424937.html

**
一、使用rand()函数
头文件<stdlib.h>

(1) 如果你只要产生随机数而不需要设定范围的话,你只要用rand()就可以了:rand()会返回一随机数值, 范围在0至RAND_MAX 间。RAND_MAX定义在stdlib.h, 其值为2147483647。

例如:

#include<stdio.h>
#include<stdlib.h>
void main()
{for(int i=0;i<10;i+)printf("%d/n",rand());
}

(2) 如果你要随机生成一个在一定范围的数,你可以在宏定义中定义一个random(int number)函数,然后在main()里面直接调用random()函数

x = rand()%11; /产生1~10之间的随机整数/

y = rand()%51 - 25; /产生-25 ~ 25之间的随机整数/

z = ((double)rand()/RAND_MAX)*(b-a) + a;/产生区间[a,b]上的随机数/

#include<iostream>
#include<stdlib.h>using namespace std;#define random(x) (rand()%x)void main() {   for (int i = 0; i < 10; i++) {cout << random(10) << " ";}cout << endl;system("pause");
}

(3)但是上面两个例子所生成的随机数都只能是一次性的,如果你第二次运行的时候输出结果仍和第一次一样。这与srand()函数有关。srand()用来设置rand()产生随机数时的随机数种子。在调用rand()函数产生随机数前,必须先利用srand()设好随机数种子(seed), 如果未设随机数种子, rand()在调用时会自动设随机数种子为1。上面的两个例子就是因为没有设置随机数种子,每次随机数种子都自动设成相同值1 ,进而导致rand()所产生的随机数值都一样。

srand()函数定义 : void srand (unsigned int seed);

通常可以利用geypid()或time(0)的返回值来当做seed,如果你用time(0)的话,要加入头文件#include<time.h>

#include<iostream>
#include<stdlib.h>
#include<time.h>using namespace std;#define random(x) (rand()%x)void main() {   srand((int)time(0));for (int i = 0; i < 10; i++) {cout << random(10) << " ";}cout << endl;system("pause");
}

1
(4)随机产生(a,b)区间内的随机数

#include<iostream>
#include<stdlib.h>
#include<time.h>
#include<iomanip>
using namespace std;
#define random(a,b) (((double)rand()/RAND_MAX)*(b-a)+a)void main() {   srand((int)time(0));for (int i = 0; i < 100; i++) {      cout << random(0, 10) << " ";}cout << endl;system("pause");
}

1
(5)四舍五入,返回整数,通过floor和ceil函数实现

#include<iostream>
#include<stdlib.h>
#include<time.h>
#include<iomanip>
using namespace std;/*四舍五入,返回整数*/
double round(double r)
{return (r > 0.0) ? floor(r + 0.5) : ceil(r - 0.5);
}
double randomRange(double a, double b)
{   double x = (double)rand() / RAND_MAX;double result = x*(b - a) + a;return round(result);
}void main() {   srand((int)time(0));for (int i = 0; i < 100; i++) {//cout << fixed << setprecision(0) << randomRange(0, 10) << " ";cout << randomRange(0, 10) << " ";}cout << endl;system("pause");
}

henry
好文要顶 关注我 收藏该文

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/418881.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Leetcode016 3Sum Closest

public class S016 {//借鉴S015的思想&#xff0c;只是稍微有点慢public int threeSumClosest(int[] nums, int target) {Arrays.sort(nums);int result nums[0]nums[1]nums[nums.length-1];for(int i 0;i<nums.length;i){if(i>0&&nums[i]nums[i-1])continue;in…

前端学习(1809):前端调试之微博头部开发

index.html <!DOCTYPE html> <html lang"en"><head><!--系统内置 start--><script type"text/javascript"></script><!--系统内置 end--><meta charset"UTF-8"><title>微博实战--head&l…

优知学院

http://youzhixueyuan.com/single-architecture-soa-micro-service-differentiation.html

数据结构实验四 排序算法的实现

广州大学学生实验报告 开课实验室&#xff1a;计算机科学与工程实验&#xff08;电子楼416&#xff09; 2019年6月4日 学院 计算机科学与教育软件学院 年级、专业、班 姓名 学号 实验课程名称 数据结构实验 成绩 实验项目名称 实验四 排序算法 指导老…

POJ1155 TELE(树形DP)

题目是说给一棵树&#xff0c;叶子结点有负权&#xff0c;边有正权&#xff0c;问最多能选多少个叶子结点&#xff0c;使从叶子到根的权值和小于等于0。 考虑数据规模表示出状态&#xff1a;dp[u][k]表示在u结点为根的子树中选择k个叶子结点的最小权值 最后就从d[1][k]中找满足…

数据结构实验五 查找算法的实现

广州大学学生实验报告 开课实验室&#xff1a;计算机科学与工程实验&#xff08;电子楼416B&#xff09; 2019年6月11日 学院 计算机科学与教育软件学院 年级、专业、班 姓名 学号 实验课程名称 数据结构实验 成绩 实验项目名称 实验五 查找算法 指导…

margin和padding的区别

https://www.cnblogs.com/zxnn/p/8186225.html

前端学习(1811):前端调试之css装饰cursor练习

index.html <!DOCTYPE html> <html lang"en"><head><!--系统内置 start--><script type"text/javascript"></script><!--系统内置 end--><meta charset"UTF-8"><title>练习</title&g…

真机调试及上线简略流程

真机调试&#xff1a; 参考完整图文教程 --》生成证书公钥文件 --》系统应用程序-使用工具-钥匙串访问--》证书助理--》从证书颁发机构请求证书--》默认选项--》存到磁盘--》继续--》生成CertificateSigningRequest.certSigningRequest公钥文件--》生成开发证书 --》开发者管理…

数据结构实验六 综合数据处理

广州大学学生实验报告 开课实验室&#xff1a;计算机科学与工程实验&#xff08;电子楼416A&#xff09; 2019年6月14日 学院 计算机科学与教育软件学院 年级、专业、班 计算机大类 144班 姓名 学号 实验课程名称 数据结构实验 成绩 实验项目名称 实验六…

JAVA高并发秒杀系统构建之——高并发优化分析

https://blog.csdn.net/yd201430320529/article/details/70544203

CSS中的text-shadow。

text-shadow&#xff08;文字投影&#xff09;&#xff0c;box-shadow&#xff08;容器投影&#xff09;&#xff0c;border-radius&#xff08;圆角&#xff09;这三个属性估计以后用的比较多&#xff0c;记录 一下。目前不支持IE系列&#xff08;不过可以使用其他方法实现&am…

计组课程设计

计算机组成与系统结构课程设计实验报告 学院&#xff1a; 计算机学科与网络工程学院 专业班级&#xff1a; 计算机科学与技术172 姓名&#xff1a; 学号&#xff1a; 2019.06.…

阿里云人脸识别sdk

https://help.aliyun.com/document_detail/64074.html?spma2c4g.11186623.6.566.107a1619AfifHp

前端学习(1803):前端调试之事件伪类练习二

index.html <!DOCTYPE html> <html lang"en"><head><!--系统内置 start--><script type"text/javascript"></script><!--系统内置 end--><meta charset"UTF-8"><title>练习</title&g…

Spring 国际化

http://www.xdemo.org/spring-i18n/ xxxx_zh_CN.properties中不允许保存中文&#xff0c;用jdk/bin目录下的native2ascii.exe将中文转化为Unicoding即可 此处是native2ascii在线转化工具http://www.javawind.net/tools/native2ascii.jsp?actiontransform转载于:https://www.cn…

JS:两个json数组合并、去重,以及删除某一项元素

https://blog.csdn.net/qq_33242126/article/details/83107866