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

用c语言写一个简易抽奖程式,要求有对档案的 *** 作,第1张

用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}

用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

}


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

原文地址: http://outofmemory.cn/yw/11468909.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-16
下一篇 2023-05-16

发表评论

登录后才能评论

评论列表(0条)

保存