头文件:

#include<stdio.h>
#include <stdlib.h>
#include<string.h>
#include <time.h>

函数原型:

void sortArray(int *a, int length); // 数组的排序

int randInMinAndMax( int range_min, int range_max );//产生一个0~max之间的某个数

void getRandArray(int *a, int length, int max); //产生某一长度的数组,它的每个元素都是随机生成的,且都在1~max之间、各不相同

void printResult(int *a, int length); //遍历数组

void getReult(char *arg, int *a1, int len1,int max1, int *a2, int len2, int max2);//产生双色球或者大乐透的结果

void hanldeArg(int argl, char *arg); //根据传入的参数判断是需要双色球还是大乐透,并跳转到相应的方法

实现方法:

 void hanldeArg(int argl, char *arg){

     int *a1 = NULL, *a2 = NULL;

     if(strcmp(arg, "双色球") == ){

         a1 = (int *)malloc(sizeof(int) * );

         a2 = (int *)malloc(sizeof(int) * );

         getReult(arg, a1, , , a2, , );

     }else if(strcmp(arg, "大乐透") == ){

         a1 = (int *)malloc(sizeof(int) * );

         a2 = (int *)malloc(sizeof(int) * );

         getReult(arg, a1, , , a2, , );

     }else
printf("参数是 双色球 或者是 大乐透 \n"); if(a1 == NULL){ free(a1); a1 = NULL; } if(a2 == NULL){ free(a2); a2 = NULL; }
}
 void getReult(char *arg, int *a1, int len1,int max1, int *a2, int len2, int max2){

     int i ;

     srand((unsigned)time(NULL));

     for(i = ; i < ; ++i){
getRandArray(a1, len1, max1); getRandArray(a2, len2, max2);
} printf("\n"); printf("%s 红球:", arg); printResult(a1, len1); printf("蓝球:"); printResult(a2, len2); printf("\n");
}
int randInMinAndMax( int range_min, int range_max )
{
int i, u; for(i = ; i < ; ++i)
u = (double)rand() / RAND_MAX * (range_max - range_min) + range_min; return u;
}
 void printResult(int *a, int length){

     int i;

     for(i = ; i < length; ++i){

         printf(" %d ", a[i]);
} }
 void getRandArray(int *a, int length, int max){

     int i, j, flag ;

     int temp;

     for(i =; i < length; ++i){

         exist : {

             //得到一个随机数
temp = randInMinAndMax(, max); flag =; //设置数组中不存在这个数 //判段数组中是否存在
for(j = i; j >= ; --j){ if(temp == a[j]){ flag = ; break;
} }
}; if(flag){ goto exist; } a[i] = temp; } sortArray(a, length);
}
void sortArray(int *a, int length){

    int i, j, temp;

    for(i = ; i < length; ++i){

        for(j = i + ; j < length; ++j){

            if(a[j] < a[i]){

                temp = a[i];

                a[i] = a[j];

                a[j] = temp;

            }

        }

    }
}

测试:

int main(int arcl, char *args[], char **env){

    if(arcl < ){

        printf("请输入参数 双色球 或者是 大乐透 \n");

        return -;

    }

    hanldeArg(arcl, args[]);

    system("pause");

    return ;

}

运行及结果:

c语言实现双色球和大乐透的更多相关文章

  1. Python实现双色球和大乐透摇奖

    实现代码: # code by kadycui # 模块引用 import random def select(): print('\n') print('请选择彩票种类') print('双色球输入 ...

  2. python模拟双色球大乐透生成算法

    每天练习一段python代码,健康生活一辈子.晚上下班没事,打开电脑继续编写python代码!今天分享的一个是大家熟悉的双色球彩票的游戏,根据这个进行写的一个python算法,代码精简,肯定有bug, ...

  3. python—模拟生成双色球号和大乐透号

    下边这个脚本,比较适合初级学习基本python语法用.但是,不精炼建议可参考https://www.cnblogs.com/Formulate0303/p/14031748.html的写法. 大乐透玩 ...

  4. Python生成随机验证码,大乐透号码

    实例笔记之生成随机号码 扩展知识 - yield(生成器) 随机生成验证码 示例代码: import random # 导入标准模块中的random if __name__ == '__main__' ...

  5. 大乐透 Java随机码

    package suijishu; import java.util.Random; // TODO Auto-generated method stub public class Xuanqi { ...

  6. python 获取大乐透中奖结果

    实现思路: 1.通过urllib库爬取http://zx.500.com/dlt/页面,并过滤出信息 2.将自己的买的彩票的号与开奖号进行匹配,查询是否中奖 3.将中奖结果发生到自己邮箱 caipia ...

  7. 08 python学习笔记-随机生成大乐透号码(八)

    1 #产生大乐透号码 2 #前区 1-32,5 后区 1-12,2 3 #1.前区从1-32中级取5个,后区再从1-12里面取2个 4 #01 02 03 04 5 def dlt(): #生成随机大 ...

  8. python 写一个生成大乐透号码的程序

    """ 写一个生成大乐透号码的程序 生成随机号码:大乐透分前区号码和后区号码, 前区号码是从01-35中无重复地取5个号码, 后区号码是从01-12中无重复地取2个号码, ...

  9. python简易的大乐透数据获取及初步分析

    该项目从网上爬取并分析彩票数据,为用户查看和初步分析往期数据提供一种简易的工具. https://github.com/unknowcry/Lottery # -*- coding: utf-8 -* ...

随机推荐

  1. Java +支付宝 +接入+最全+最佳-实战-demo

    一.支付宝配置: 1.需要在支付宝商户平台购买支付的产品并开通支付. 2.购买支付产品登录支付宝:https://auth.alipay.com/login/index.htm 3.登录之后首页点击查 ...

  2. python开发基础--思维导图

    开始学习python,相当于零基础 非自学,自学的痛苦不想体会和尝试,毕竟不会很友好,知乎上看到很多说自学的好处啊噼里啪啦的.嗯,说的很对,但是我偏不听,略略略.锻炼我的自学能力,这还需要锻炼吗,百度 ...

  3. Kotlin的特性

    time streams try-with-resources 函数扩展,给types.classes或者interfaces新增方法 null safe 不需要new,后缀声明类型 自动转换有get ...

  4. CPU中的cache结构以及cache一致性

    一. 引子 在多线程环境中,经常会有一些计数操作,用来统计线上服务的一些qps.平均延时.error等.为了完成这些统计,可以实现一个多线程环境下的计数器类库,方便记录和查看用户程序中的各类数值.在实 ...

  5. 链表:如何实现LRU缓存淘汰算法?

    缓存淘汰策略: FIFO:先入先出策略 LFU:最少使用策略 LRU:最近最少使用策略   链表的数据结构: 可以看到,数组需要连续的内存空间,当内存空间充足但不连续时,也会申请失败触发GC,链表则可 ...

  6. 防止Web攻击,做好HTTP安全标头

    前言   下图是几年前一位女性在访谈会上提问Linus(Linux操作系统之父) 为什么英伟达显卡在Linux系统中兼容性这么差? Linus说他们曾经去和英伟达谈过关于显卡在Linux上兼容的问题, ...

  7. 重读《学习JavaScript数据结构与算法-第三版》- 第5章 队列

    定场诗 马瘦毛长蹄子肥,儿子偷爹不算贼,瞎大爷娶个瞎大奶奶,老两口过了多半辈,谁也没看见谁! 前言 本章为重读<学习JavaScript数据结构与算法-第三版>的系列文章,主要讲述队列数据 ...

  8. Django Mysql数据库-基于双下划线的跨表查询

    一.基于双下划线的跨表查询 Django 还提供了一种直观而高效的方式在查询(lookups)中表示关联关系,它能自动确认 SQL JOIN 联系.要做跨关系查询,就使用两个下划线来链接模型(mode ...

  9. sql server 日期近一年,同比

    --近一年 ), , , ) SELECT CONVERT(VARCHAR, DATEADD(day, -DAY(GETDATE()), , ) --同比 ), , , ) SELECT CONVER ...

  10. Java网络编程 -- BIO 阻塞式网络编程

    阻塞IO的含义 阻塞(blocking)IO :阻塞是指结果返回之前,线程会被挂起,函数只有在得到结果之后(或超时)才会返回 非阻塞(non-blocking)IO :非阻塞和阻塞的概念相对应,指在不 ...