c语言实现双色球和大乐透
头文件:
#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语言实现双色球和大乐透的更多相关文章
- Python实现双色球和大乐透摇奖
实现代码: # code by kadycui # 模块引用 import random def select(): print('\n') print('请选择彩票种类') print('双色球输入 ...
- python模拟双色球大乐透生成算法
每天练习一段python代码,健康生活一辈子.晚上下班没事,打开电脑继续编写python代码!今天分享的一个是大家熟悉的双色球彩票的游戏,根据这个进行写的一个python算法,代码精简,肯定有bug, ...
- python—模拟生成双色球号和大乐透号
下边这个脚本,比较适合初级学习基本python语法用.但是,不精炼建议可参考https://www.cnblogs.com/Formulate0303/p/14031748.html的写法. 大乐透玩 ...
- Python生成随机验证码,大乐透号码
实例笔记之生成随机号码 扩展知识 - yield(生成器) 随机生成验证码 示例代码: import random # 导入标准模块中的random if __name__ == '__main__' ...
- 大乐透 Java随机码
package suijishu; import java.util.Random; // TODO Auto-generated method stub public class Xuanqi { ...
- python 获取大乐透中奖结果
实现思路: 1.通过urllib库爬取http://zx.500.com/dlt/页面,并过滤出信息 2.将自己的买的彩票的号与开奖号进行匹配,查询是否中奖 3.将中奖结果发生到自己邮箱 caipia ...
- 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(): #生成随机大 ...
- python 写一个生成大乐透号码的程序
""" 写一个生成大乐透号码的程序 生成随机号码:大乐透分前区号码和后区号码, 前区号码是从01-35中无重复地取5个号码, 后区号码是从01-12中无重复地取2个号码, ...
- python简易的大乐透数据获取及初步分析
该项目从网上爬取并分析彩票数据,为用户查看和初步分析往期数据提供一种简易的工具. https://github.com/unknowcry/Lottery # -*- coding: utf-8 -* ...
随机推荐
- Java +支付宝 +接入+最全+最佳-实战-demo
一.支付宝配置: 1.需要在支付宝商户平台购买支付的产品并开通支付. 2.购买支付产品登录支付宝:https://auth.alipay.com/login/index.htm 3.登录之后首页点击查 ...
- python开发基础--思维导图
开始学习python,相当于零基础 非自学,自学的痛苦不想体会和尝试,毕竟不会很友好,知乎上看到很多说自学的好处啊噼里啪啦的.嗯,说的很对,但是我偏不听,略略略.锻炼我的自学能力,这还需要锻炼吗,百度 ...
- Kotlin的特性
time streams try-with-resources 函数扩展,给types.classes或者interfaces新增方法 null safe 不需要new,后缀声明类型 自动转换有get ...
- CPU中的cache结构以及cache一致性
一. 引子 在多线程环境中,经常会有一些计数操作,用来统计线上服务的一些qps.平均延时.error等.为了完成这些统计,可以实现一个多线程环境下的计数器类库,方便记录和查看用户程序中的各类数值.在实 ...
- 链表:如何实现LRU缓存淘汰算法?
缓存淘汰策略: FIFO:先入先出策略 LFU:最少使用策略 LRU:最近最少使用策略 链表的数据结构: 可以看到,数组需要连续的内存空间,当内存空间充足但不连续时,也会申请失败触发GC,链表则可 ...
- 防止Web攻击,做好HTTP安全标头
前言 下图是几年前一位女性在访谈会上提问Linus(Linux操作系统之父) 为什么英伟达显卡在Linux系统中兼容性这么差? Linus说他们曾经去和英伟达谈过关于显卡在Linux上兼容的问题, ...
- 重读《学习JavaScript数据结构与算法-第三版》- 第5章 队列
定场诗 马瘦毛长蹄子肥,儿子偷爹不算贼,瞎大爷娶个瞎大奶奶,老两口过了多半辈,谁也没看见谁! 前言 本章为重读<学习JavaScript数据结构与算法-第三版>的系列文章,主要讲述队列数据 ...
- Django Mysql数据库-基于双下划线的跨表查询
一.基于双下划线的跨表查询 Django 还提供了一种直观而高效的方式在查询(lookups)中表示关联关系,它能自动确认 SQL JOIN 联系.要做跨关系查询,就使用两个下划线来链接模型(mode ...
- sql server 日期近一年,同比
--近一年 ), , , ) SELECT CONVERT(VARCHAR, DATEADD(day, -DAY(GETDATE()), , ) --同比 ), , , ) SELECT CONVER ...
- Java网络编程 -- BIO 阻塞式网络编程
阻塞IO的含义 阻塞(blocking)IO :阻塞是指结果返回之前,线程会被挂起,函数只有在得到结果之后(或超时)才会返回 非阻塞(non-blocking)IO :非阻塞和阻塞的概念相对应,指在不 ...