C语言中生成随机数(任意范围随机数,并抽取其中某些数)
创作时间:
作者:
@小白创作中心
C语言中生成随机数(任意范围随机数,并抽取其中某些数)
引用
CSDN
1.
https://m.blog.csdn.net/m0_63207201/article/details/136960672
一、理解思路
- 产生所需范围内的随机数
- 取其中n个随机数,去除重复随机数
- 排序输出
二、代码演示
#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <time.h>
int comp_int(const void* e1, const void* e2) {
return *(char*)e1 - *(char*)e2;
}
int main() {
srand((unsigned)time(NULL));
int rangStart = 0; // 随机数的开始范围
int rangEnd = 0; // 随机数的结束范围
scanf("%d-%d", &rangStart, &rangEnd);
int amount = 0; // 取随机数的个数
scanf("%d", &amount);
int i = 0;
int randArr[100] = { 0 };
for (i = 0; i < amount; i++) {
int j = 0;
do {
randArr[i] = rand() % (rangEnd - rangStart + 1) + rangStart;
// 去除重复
for (j = 0; j < i; j++) {
if (randArr[i] == randArr[j])
break;
}
} while (i != j);
}
// 排序
qsort(randArr, amount, sizeof(randArr[0]), comp_int);
// 打印
for (i = 0; i < amount; i++) {
printf("%d ", randArr[i]);
}
return 0;
}
运行结果:
三、rand和srand
rand:随机数发生器,所需头文件stdlib.hsrand:初始化随机数发生器,所需头文件stdlib.h。参数需要引用头文件time.h
rand()和srand()要一起使用,其中srand()用来初始化随机数种子,rand()用来产生随机数。
默认情况下随机数种子为1,相同的随机数种子产生的随机数是一样的,这就是伪随机数。所以为使每次得到的随机数不一样,用函数srand()初始化随机数种子。srand()的参数,用time函数值(表示当前的时间),因为每次调用rand()函数的时间是不同的,这样就可以保证随机性了。
代码示例:
- 任何一个数A取余(模)另外一个数B(都不为0),即 A % B,区间的范围是: 0到 B-1。
- 生成 0-10 之间的随机数,
rand % (10+1),区间范围是0-10。 - 如果需要产生1-10之间的随机数,即
rand %10,得到的区间范围是0-9,所以rand%10 + 1得到 1- 10范围。 - 如果是生成 3-10,我们可以先得到0-7的范围,再+3。因为0-7的范围可以直接求得
rand %(10-3+1), 3-10范围即为rand%8 + 3
四、去除重复随机数
在生成随机数的过程中,肯定会出现重复的数字,这个时候我们需要对随机数去重,所以我们可以定义一个数组,把生成的随机数一个个存起来,然后去除重复。
如果数组的1 2 3 4 5,后面再得到一个随机数3,把前面所有的随机数逐次比较。
当i下标变成5的时候,j从0 开始遍历数组,范围是1-5中对比,
如果出现相同的数字直接跳出内部for循环,再次回到do{重新生成随机数},
也就是说i的下标还是5,跳出去之后, i肯定不会等于j,所以while中的判断条件是 i != j,
再次重新生成随机数,如果随机数不是3,是8,内部循环j不断++,直到变成最后判断结束,再+1次,j==i,跳出do while 循环,此时i就会自增了。
五、排序
排序可以使用冒泡排序,这里使用的是排序函数qsort,qsort所需要的头文件是stdlib.h
qsort函数所需参数,这里引用他人文章:qsort函数的使用
最后再打印就得到了所需要的结果。通常情况下,建议使用qsort来完成排序。
热门推荐
“精准帮教挽救迷途少年”——武汉大学罪错未成年人分级干预的困境与出路专题社会实践
学生突发呼吸性碱中毒!医护人员:紧急用塑料袋套住其口鼻!
如何应对在美国开储蓄卡后忘记注销的问题:全面指南
如何计算房屋的空置费用?这种费用的计算依据是什么?
肠子比较容易“激动”?医生:建议这样缓解尴尬和不适
长期卧床病人的皮肤护理指南
深入理解 Git Reset 的三种模式及其使用场景
日晷及其原理解析
如何修复服务器 400 问题(解决错误)
聚丙烯酰胺(PAM)在污水处理中的关键角色与应用
配音入门:基本功的重要性与训练方法
大国崛起,12年,从0到3!中国海军的“三航母之路”!
板材厚度的选择建议
让学校从“无限责任”中“脱困”!
小米集团成交额超717亿港元创历史天量;南山铝业国际上市首日破发丨港交所早参
为什么要评估房子(房屋评估报告有什么用)
汽车座位数-汽车座位数不含司机座是什么意思
空置房该不该交暖气费,空置房应否承担暖气费?
兔子上厕所训练方法是什么?需要多长时间才能学会?
洛氏、布氏、维氏、努氏硬度之间的换算公式大全
如何编制车牌号以符合规定?这种编制对车辆管理有何法律意义?
大国基建再“更新” “硬核”科技带来“中国速度”
逍客两万公里要做什么保养
UVLED 设备在印刷行业的变革性应用
2025年3月花生种植技术全攻略:从品种选择到播后管理
古兰经比圣经更古老吗?
Nature子刊:冯建峰团队等利用智能算法定义三种抑郁症生物亚型
当下流行发型之美:短发带层次,蓬松且有线条感
建筑行业农民工的背影——分析与思考
什么是中控台