摇奖机摇奖,无非就是利用它的随机性,让球从摇奖机中随机地掉出,就成了中奖号码。而C语言中也同样有个rand()函数可以产生随机数,利用这个rand()函数产生的随机数,同样可以代替从摇奖机中随机摇出的中奖号码。
然而,我们无法直接使用rand()函数来产生中奖号码,因为rand()产生的随机数字有一定的重复性,也就是rand()也许可以产生两个1,三个2,这显然不符合彩票的规则。那么,如何让rand()产生不重复的随机数字呢?
我们可以回想一下摇奖机是如何工作的:从容器中随机地摇出一个球,然后再从设个拿下的号码球中摇出第二个球。。。以此类推。而在C语言程序中,我们要想产生不重复的随机数字,也可以模仿这个过程来产生随机数字。首先在一个数组balls中保存所有的彩球号码(从1到22),然后,用rand()产生一个数组中号码个数范围内的随机数n(产生一个0到21范围内的随机数),然后用这个数n作为数组下标,从balls数组中取出的数字balls[n]就是摇出的号码,然后复制保存到中奖号码数组winnings中(winning[i]=balls[n]),因为一个号码已经被摇出了,所以我们将末尾的号码复制到已经被摇出的号码的位置(balls[n] = balls[M-i];),这样,这个数组中前面部分的号码依然是有效的,这是可以开始摇第二个球,用rand()产生一个0到20范围的随机数,得到第二个号码,以此类推,我们就可以得到五个随机的不重复的中奖号码了。
根据上面的分析,我们将这个摇奖程序实现如下:

// shuffle.c 福彩摇奖程序
// 中原风采22选5游戏规则
// 中原风采22选5属于低难度乐透型彩票,
// 彩民只需从01至22个号码中任意选出5个号
// 码就可以组成一注。开奖后将投注号码与中
// 奖号码对照,没有特别号码,不排顺序和位置。
#include <stdio.h>
#include <stdlib.h>
// 引入rand(),srand()函数所在头文件
#include <time.h>
const int M = ;
// 号码总数 const
int N = ;
// 摇出的号码数
// 将22个号码装入摇奖机
void init(char* balls )
{
for(int i=;i<M;++i)
{
balls[i] = i + ;
}
}
// 摇奖,将中奖号码摇出到winnings数组 v
void shuffle(char* balls,char* winnings)
{
// 用当前时间初始化随机种子
srand(time(NULL));
// 依次摇出N个中奖号码
for(int i = ; i < N; ++i)
{
// 得到一个0到(M-i)之间的随机数
int n = rand()%(M - i);
// 将摇出的号码复制到winnings保存
winnings[i] = balls[n];
// 用balls末尾的数字填补摇出号码的空位
balls[n] = balls[M-i];
}
}
int main(void)
{
// 准备摇奖
char balls[M];
init(balls);
// 摇啊摇,摇啊摇
char winnings[N];
shuffle(balls,winnings);
// 公布中奖号码,可惜中奖的不是我
puts("winning numbers:");
for(int i = ; i < N; ++i)
{
printf("%d ",winnings[i]);
}
return ;
}

这里大家可能还有个疑问:这种方法,真的能够保证每个号码出现的几率都是一样的吗?比如,我们以数字1为例,1第一次就被摇出的几率,很明显是1/22,假如1第一次没被摇出,那么他第一次不被摇出的几率就是21/22,而这是只剩下了21个球,他第二次别摇出的几率就是1/21?啊,1/21不是比1/22高?几率不均等啊。且慢,虽然1第二次摇出的几率要高,但是这是在第一次不被摇出的基础之上的,所以他实际上第二次被摇出的几率是,(21/22)*(1/21)=1/22,依然是1/22,两次的几率实际上是一样的。

转载:http://www.chenlq.net/books/c-mate/learn-the-c-language-how-to-write-a-lottery-program-selected-5-winning-numbers-shake-out-22.html

C语言,一个彩票摇奖程序摇出22选5的中奖号码的更多相关文章

  1. P235 实战练习(集合类2)、摇奖程序和验证码(修改版)

    1.分别向Set集合以及List集合中添加“A”.“a”.“c”.“C”.“a”5个元素,观察重复值“a”能否在List集合以及Set集合中成功添加. package org.hanqi.practi ...

  2. C#摇奖程序

    private void Form1_Load(object sender, EventArgs e) { //取消跨线层访问控件的判断 Control.CheckForIllegalCrossThr ...

  3. C语言一个简单的闹钟程序

    #include <stdio.h> #include <stdbool.h> #include <Windows.h> ; i < ; ++i) { // ...

  4. 学了C语言,如何写个程序计算出每个月的第一个星期一对应的日期

    在前面,我们分别利用泰勒公式和C标准库中的mktime()函数推算了某个特定日期所对应的星期几,刚做完这些,就又遇到了一个与日期相关的新任务: 老板把每个月例会的时间定在了每个月的第一个星期一,他让我 ...

  5. [AHOI2001]彩票摇奖

    [AHOI2001]彩票摇奖 题目描述 为了丰富人民群众的生活.支持某些社会公益事业,北塔市设置了一 项彩票.该彩票的规则是: (1) 每张彩票上印有 7 个各不相同的号码,且这些号码的取指范围为 1 ...

  6. P1074 彩票摇奖

    题目描述 为了丰富人民群众的生活.支持某些社会公益事业,北塔市设置了一项彩票.该彩票的规则是: (1) 每张彩票上印有 7 个各不相同的号码,且这些号码的取指范围为 1~33. (2) 每次在兑奖前都 ...

  7. 题解 P2550 【[AHOI2001]彩票摇奖】

    题目链接 大家有没有发现数据范围好小呀 我们只需要开7~8的数组就好!! 中间比较的时候懒得用for循环比较了.直接爆搜. 废话不多说,直接上代码. #include<bits/stdc++.h ...

  8. php摇杆Tiger摇奖

    先说下整体思路,代码已附下方. 1.递归产生一个非中奖数(即非连续数字:'111','222','333','444','555','666','777','888') 2.点击摇奖,把奖项通过设置的 ...

  9. 异步委托 多线程实现摇奖器 winform版

    using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using Sy ...

随机推荐

  1. Linux系统木马后门查杀方法详解

    木马和后门的查杀是系统管理员一项长期需要坚持的工作,切不可掉以轻心.以下从几个方面在说明Linux系统环境安排配置防范和木马后门查杀的方法: 一.Web Server(以Nginx为例) 1.为防止跨 ...

  2. 007--VS2013 C++ 显示位图半透明化

    以后所有图片都放在根目录下: 如有另放,会特别注明 //全局变量HBITMAP bg,girl;HDC mdc; //起始坐标const int xstart = 50;const int ystar ...

  3. run.do 文件编写说明

    #停止仿真quit -sim#清除信息.main clear #建立物理路径libvlib ./lib/#建立物理路径work_avlib ./lib/work_a/#映射逻辑库至物理路径vmap b ...

  4. verilog简易实现CPU的Cache设计

    verilog简易实现CPU的Cache设计 该文是基于博主之前一篇博客http://www.cnblogs.com/wsine/p/4661147.html所增加的Cache,相同的内容就不重复写了 ...

  5. How to compile and install NCAR Command Language on IBM PowerPC 64 --- NCL编译安装步骤

    作者:Sinsonglew 出处:http://www.cnblogs.com/sinsonglew 欢迎转载,也请保留这段声明.thanks :) 注记:NCL官方依赖安装包全集列表.官方源码编译指 ...

  6. Sprint会议-初步组织划分

    主题:Spring冲刺计划会议,组员已认领方式领取任务,对个人任务进行详细划分. 日期:2015.4.26 地点:学一食堂二楼 与会人员:王雪青.陆宇.徐擎天.张文冬.赵建松 索引表 因早期任务的认领 ...

  7. jQuery实现模拟滚动条效果;

    滚动条在web开发中,很常见,原生的HTML滚动条很难看,因此很多网站借助JS来模拟实现滚动条效果: 滚动条的实现原理其实比较简单,拿垂直滚动条来说: 1),最外层容器需要设置overflow:hid ...

  8. LabView调用C#混合模式dll

    在一些特定要求下,我们的C#可能需要制作dll给LabView进行调用,并且我们不能够保证C#的程序是完全自己写而不调用第三方的dll库.很多时候我们需要使用诸如Sqlite.Net.AForge.N ...

  9. 尝试用Uplodify

    尝试用Uplodify     Uplodify官方 前台index代码: @{ Layout = null; } <script src="~/Scripts/jquery-1.8. ...

  10. python-面向对象(股票对象举例)

    股票对象实例 class Stock(object): def __init__(self,stockCode ,stockName,averagePrice_yesterday,averagePri ...