(c语言版)使用随机函数rand

随机函数rand()详解

随机生成1-31号红球5个,随机生成1-16号白球2个,红球白球分别按照从小到大的顺序排序

c 复制代码
#include<stdio.h>
#include<stdlib.h>
int main() {
    int n = 0;
    int a[7] = {0};
    while (n < 5) {
        a[n++] = rand() % 32;
    }
    a[n++] = rand() % 17;
    a[n++] = rand() % 17;
    printf("随机生成的数字为:");
    for (int i = 0; i < n; i++) {
        printf("%d ", a[i]);
    }
    for(int i=0;i<4;i++){
        for(int j=0;j<4-i;j++){
            if(a[j]>a[j+1]){
                int t=a[j];
                a[j]=a[j+1];
                a[j+1]=t;
            }
        }
    }
    if(a[5]>a[6]){
        int t=a[5];
        a[5]=a[6];
        a[6]=t;
    }
    printf("排序后结果为:");
    for(int i=0;i<7;i++){
        printf("%d ",a[i]);
    }
    return 0;
}

标准写法

c 复制代码
#include<stdio.h>
#include<stdlib.h>
void getball(int *ball,int count,int base){          //count是要取走的球,编号为1-base
    int i=0;
    int a[31]={0};
    for(int i=0;i<base;i++){
        a[i]=i+1;
    }
    i=0;
    while(i!=count){
        int t=rand()%(31-i);
        ball[i]=a[t];
        a[t]=a[31-i-1];                      //最后一个球移过去,体现球的已取走
        i++;
    }
}
void sort(int a[],int n){
    for(int i=0;i<n;i++){
        for(int j=0;j<n-1;j++){
            if(a[j+1]<a[j]){
                int t=a[j];
                a[j]=a[j+1];
                a[j+1]=t;
            }
        }
    }
}
int main(){
    int ball[7]={0};
    getball(ball,5,31);
    getball(ball+5,2,16);
    sort(ball,5);
    sort(ball+5,2);
    for(int i=0;i<7;i++){
        printf("%d ",ball[i]);
    }
    return 0;
}
相关推荐
老猿讲编程13 小时前
提升ARM Cortex-M系统性能的关键技术:TCM技术解析与实战指南
arm开发·arm·c
科大饭桶1 天前
数据结构自学Day15 -- 非比较排序--计数排序
数据结构·算法·leetcode·排序算法·c
鑫宇吖2 天前
IAR编辑器如何让左侧的工具栏显示出来?
编辑器·嵌入式·c·iar
科大饭桶4 天前
数据结构自学Days10 -- 二叉树的常用实现
数据结构·算法·leetcode·二叉树·c
Tipriest_5 天前
cddlib(用于凸多面体计算和线性不等式系统求解)的开源库
c·cddlib·优化计算·凸多面体·线性不等式求解
科大饭桶5 天前
数据结构自学Day12-- 排序算法2
数据结构·算法·leetcode·排序算法·c
一棵开花的树,枝芽无限靠近你5 天前
数据结构之克鲁斯卡尔算法
数据结构·算法·c
科大饭桶6 天前
数据结构自学Day11-- 排序算法
数据结构·算法·leetcode·排序算法·c
青草地溪水旁7 天前
`MYSQL`、`MYSQL_RES` 和 `MYSQL_FIELD`的含义与使用案例
数据库·mysql·c
一棵开花的树,枝芽无限靠近你7 天前
数据结构之普利姆算法
数据结构·算法·c