(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;
}
相关推荐
不吃土豆的马铃薯14 小时前
Spdlog 入门:日志记录器与日志槽基础详解
服务器·开发语言·c++·c·日志·spdlog
金创想17 小时前
积木移动题目分析及解题思路——木块问题(1)
c++·算法·字符串·c·刷题·信息学奥赛·积木
不吃土豆的马铃薯4 天前
5.SGI STL 二级空间配置器 _S_chunk_alloc核心函数解析
开发语言·c++·vscode·c·内存池
一只小灿灿5 天前
深度详解计算机补码原理
c·补码
liulilittle5 天前
TCP UCP v1.0 拥塞控制算法(Linux Kernel CC-A)
linux·网络·网络协议·tcp/ip·c·通信·拥塞控制
weixin_421725265 天前
Linux 编程语言全解析:C、C++、Python、Go、Rust 谁更强?
linux·python·go·c·编程语言
REDcker6 天前
C++循环与编译器优化详解 别名不变量向量化与GCC Clang验证及perf实践
java·jvm·c++·c·clang·gcc
charlie1145141917 天前
通用GUI编程技术——图形渲染实战(四十三)——D3D12设计哲学:显式控制与性能解锁
学习·3d·c·图形渲染·win32
liulilittle8 天前
TCP UCP v1.0:BBR 的非破坏性约束层
网络·c++·网络协议·tcp/ip·算法·c·通信
lightqjx11 天前
【Linux】第一个小程序:进度条
linux·服务器·学习·缓存·c·进度条实现