问小白 wenxiaobai
资讯
历史
科技
环境与自然
成长
游戏
财经
文学与艺术
美食
健康
家居
文化
情感
汽车
三农
军事
旅行
运动
教育
生活
星座命理

C语言中生成随机数(任意范围随机数,并抽取其中某些数)

创作时间:
作者:
@小白创作中心

C语言中生成随机数(任意范围随机数,并抽取其中某些数)

引用
CSDN
1.
https://m.blog.csdn.net/m0_63207201/article/details/136960672

一、理解思路

  1. 产生所需范围内的随机数
  2. 取其中n个随机数,去除重复随机数
  3. 排序输出

二、代码演示

#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.h
  • srand:初始化随机数发生器,所需头文件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就会自增了。

五、排序

排序可以使用冒泡排序,这里使用的是排序函数qsortqsort所需要的头文件是stdlib.h

qsort函数所需参数,这里引用他人文章:qsort函数的使用

最后再打印就得到了所需要的结果。通常情况下,建议使用qsort来完成排序。

© 2023 北京元石科技有限公司 ◎ 京公网安备 11010802042949号