用vb编写抽奖程序

用vb编写抽奖程序,第1张

一、界面设计

新建一个标准的exe工岩帆程。在form1窗体中放置一个定时器(timer1)、两个文本框(label1,label2)、两个命令按钮(command1,command2)和包含7个元素的控件数组(label3(0)—label3(6))。

二、属性设置

label3控件数组中的所有元素皆采用相同设置。

三、代码编写

本程序的实现原理是:当用户单击“开始”按钮时,打开定时器,利用定时器控件同时产生两个随机数sj1、sj2,sj1的范围是1~32,sj2的范围是0~49。当sj1=24的时侯,用sj2与前面产生的中奖号码作比较,若与前面的中奖带数相同,则退出本过程;若与前面的中奖号码不同,则将此随机数作为中奖号码。当产生了7个中奖蠢枣首号码时,关闭定时器控件,停止产生随机数。

本程序用到的函数简介:

(1)randomize:初始化随机数的种子数。

(2)int():返回一个非整形数字取整后的整数。

(3)rnd:产生一个0~1之间的随机数(大于等于0,但小于1)。

(4)qbcolor():返回参数(0~15)对应的颜色。

(5)val:将一个字符形变量转化为一个数值型变量。

(6)format:格式化一个表达式。

以下是程序的完整代码:

dim sy as integer

′命令按钮1的单击事件

private sub command1_click()

′清除label3控件数组的内容

for i=0 to 6

label3(i).caption=″″

next

timer1.enabled=true′打开定时器

command1.enabled=false′使开始按钮失效

sy=-1′索引值初始化为-1

end sub

′命令按钮2的单击事件

用c语言写一个简易抽奖程式,要求有对档案的 *** 作 hello; 20个号码在萤幕上滚动输出,可以用时间函式和清屏函式处理。最后回车运碰键选中停止,其实也就是一个跳出死回圈的步骤。嗯,这样应该可以了吧。我也没做,很久没写程式了。你试着写一下。

用c语言写一个简易抽奖程式,要求涉及到档案的 *** 作

#include <bits/stdc++.h>using namespace std int n,a[233] int main(){ freopen("a.in","r",stdin) freopen("a.out","w",stdout) scanf("%d",&n) for (int i=0i<ni++) scanf("%d",&a[i]) printf("%d\n",a[rand()%n]) }

求用c语搏举言自制一个简易抽奖程式

用data.txt档案储存以下内容:

13725528132 李桂荣

13725528131 李二来

13725528133 张荣刚

13725528130 荣南

13725528137 王三

13725528138 吴立

13725528139 郭德纲

13725528140 周星驰

13725528141 张曼玉

13725528142 张艺谋

13725528152 秦香莲

13725528162 潘金莲

13725528172 李大嘴

13725528182 展堂

原始码如下

#include <stdio.h>

#include <stdlib.h>

#include <time.h>

#define MAX_NUM 9999

定义储存人名和电话的资料结构

struct Person

{

char name[20]

char telno[15]

char award

}

int num = 0统计人数

FILE *fp档案指标

Person persons[MAX_NUM]定义阵列

int awarder_1[1] = {-1}一等奖

int awarder_2[2] = {-1, -1}二等奖

int awarder_3[5] = {-1, -1, -1, -1, -1}三等奖

读取档案

void readdata()

{

int i = 0阵列下标

Person person

档案开启

fp = fopen("data.txt", "r")

if (fp == NULL)

{

printf("开启档案data.txt失败!\n")

return

}

当档案不为空

while (!feof(fp))

{

num ++

fscanf(fp, "%s", person.telno)

fscanf(fp, "%s", person.name)

person.award = 'F'

persons[i++] = person

}

}

初始化标识

void init()

{

for(int i = 0i <numi++)

{

persons[i].award = 'F'

}

}

显示单个中奖资讯

void info( int i)

{

printf("手机旁银谈号码: %s 姓名: %s\n", persons[i].telno, persons[i].name)

}

void main()

{

char again = 'Y'

读取档案

readdata()

printf("简单抽奖程式\n")

srand((long)time(0))

while(again == 'Y' || again == 'y')

{

初始化标识

init()

printf("\n开始抽第一等奖(1名),按任意键开始...\n")

getchar()

awarder_1[0] = abs(rand() % num)

while (persons[awarder_1[0]].award == 'T')

{

awarder_1[0] = rand() % num

}

persons[awarder_1[0]].award = 'T'

info(awarder_1[0])

printf("\n开始抽第二等奖(2名)\n")

for (int i = 0i <2i++)

{

printf("\n第%d个二等奖,按任意键开始...\n", i+1)

getchar()

awarder_2[i] = rand() % num

while (persons[awarder_2[i]].award == 'T')

{

awarder_2[i] = rand() % num

}

persons[awarder_2[i]].award = 'T'

info(awarder_2[i])

}

printf("\n\n开始抽第三等奖(5名)\n")

for (i = 0i <5i++)

{

printf("\n第%d个三等奖,按任意键开始...\n", i + 1)

getchar()

awarder_3[i] = rand() % num

while (persons[awarder_3[i]].award == 'T')

{

awarder_3[i] = rand() % num

}

persons[awarder_3[i]].award = 'T'

info(awarder_3[i])

}

printf("\n是否重新开始抽奖?(Y or N)...\n")

again = getchar()

}

getchar()

return

}

C语言怎么写一个简易秒表

用到time.h档案

里面有个clock()函式,返回一个clock_t型别的数字,表示从程式执行开始,CPU的"滴答"数

而在time.h里有个常量CLOCKS_PER_SEC表示每秒钟有多少个"滴答".

这样,(((float)clock())/CLOCKS_PER_SEC)*1000这样的表示式就能得到从程式执行开始到现在的经过的时间.

程式的大致思路是这样的,程式按下1的时候记下当时的程式执行时间.

从这时起,每时刻捡取程式执行时间,然后减去先前的值,就可以得到已经计时的时间了.

只要让使用者按下0结束计时就好了

在conio.h档案里,有个函式kbhit()是个非阻塞函式,用来检查键盘缓冲里有没有按键按下,若有,则返回1,若没有,则返回0,以此来作为判断,若返回1,则捡取按键,测试它是不是0或者1,若返回0,则表示使用者没有动作,继续原来的工作,即继续计时或等待命令.

时间紧,求帮写一个简单C语言程式

#include <stdio.h>

void show(int i)

{

switch(i) {

case 0:

printf("零")

break

case 1:

printf("壹")

break

case 2:

printf("贰")

break

case 3:

printf("叁")

break

case 4:

printf("肆")

break

case 5:

printf("伍")

break

case 6:

printf("陆")

break

case 7:

printf("柒")

break

case 8:

printf("捌")

break

case 9:

printf("玖")

break

}

}

void showwei(int i)

{

if (i != 5 &&i != 9) { 不是万位和亿位

i = i % 4

}

switch(i){

case 2:

printf("拾")

break

case 3:

printf("佰")

break

case 4:

printf("千")

break

case 5:

printf("万")

break

case 9:

printf("亿")

break

}

}

void test1(int n)

{

int i = 0

int j

int b[20]

while(1) {

b[i] = n % 10

i++

n = n / 10

if (n == 0) {

break

}

}

for(j = i - 1j >= 0j--) {

show(b[j]) 输出一二三四

}

printf("\n")

for(j = i - 1j >= 0j--) {

show(b[j])

showwei(j +1) 输出十百千万

}

printf("\n")

}

void main()

{

long int i

printf("请输入整数:")

scanf("%ld",&i)

test1(i) 输出繁体

}

用c语言写一个简易数独的思路。要程式码

#include<stdio.h>int num[9][9], xy[9][9]int check(int x, int y) {int i, m, n for(i = 0i <9i++)if ((xy[x][y] == xy[i][y]&&i != x)||(xy[x][y] == xy[x][i]&&i != y))return 0 for(i = 0, m = x / 3 * 3, n = y / 3 * 3i <9i++)if (xy[x][y] == xy[m + i / 3][n + i % 3]&&m + i / 3 != x&&n + i % 3 != y)return 0 return 1}void search(int x, int y) {if (x == 9)for(x = 0x <9x++) {for(y = 0y <9y++)printf("%d ", xy[x][y]) printf("\n") }else if (num[x][y])search(x + (y + 1) / 9, (y + 1) % 9) elsefor(xy[x][y] = 1xy[x][y] <= 9xy[x][y]++)if (check(x, y))search(x + (y + 1) / 9, (y + 1) % 9) return}int main() {int i, j for(i = 0i <9i++)for(j = 0j <9j++) {scanf("%d", &num[i][j]) xy[i][j] = num[i][j] }search(0, 0) return 0} 输入为9行9列整数,已知的整数填写对应的数字,尚待计算的未知数字填写0。

该程式码的思路很简单,就是从第一行第一列开始依次填入数字,检查是否是在同一行、同一列、同一宫有没有填入重复数字,如果没有就继续填入下一个数字,如果有就返回。

虽然效率稍低,但原理简单、表述直白、易于理解,更有效率的程式码是使用十字连结串列完成,如有兴趣可继续深入

编写C语言程式,实现对磁碟档案的 *** 作

#include "stdio.h"

#include "string.h"

main()

{

FILE *fp

fp=fopen("data.txt","w")

char a[100]="hello world!"

fwrite(a,strlen(a)+1 ,sizeof(char),fp )

fclose(fp)

fp=fopen("data.txt","r")

char b[100]

fread(b,strlen(a)+1 ,sizeof(char),fp )

fclose(fp)

printf("%s\n",b)

}

c语言,写一个抽奖程式,可以选择重复抽奖也可以选择退出,能调概率

srand(time(0));

int chance;

输入概率(10 - 100 %)

rand() % chance == 0 为中奖;

其他不中;

帮忙写一个c语言程式,作用是写一个分割档案的程式,原档案太大,无法装的下,需要分割

#include <stdio.h>#include <string.h>#define TARGET_SIZE (100*1024*1024) 分割为100M一个档案int main(){char name[100] FILE *in, *out char target[100] int t=1,c, n=0 printf("input source file name and path:") gets(name) in = fopen(name, "rb") if(in == NULL){printf("can not read file\n") return -1 }while(!feof(in)){sprintf(target, "%s.part%d",name, t) out = fopen(target, "wb") if(out == NULL){printf("open %d file to write failed\n",t) return -1 }n = 0 while((c=fgetc(in)) != EOF &&n<TARGET_SIZE){fputc(c, out) n++ }fclose(out) t ++ }fclose(in) printf("done! the file is cut to %d file(s)\n", t-1) return 0}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/12494583.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2025-08-25
下一篇2025-08-25

发表评论

登录后才能评论

评论列表(0条)

    保存