//一个随机点名器程序,因为代码量较少,我就没有封装函数
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <time.h>
#include <unistd.h>
#include <stdbool.h>
int main(int argc, char const *argv[])
{
FILE *fp;
time_t t = time(NULL);
int k = 0; //存放生成的随机数
char str[150][20]; //存放从文件中读取出来的名字
char s2[150][20]; //存放最终抽取出来的名字
char targetname[150] = {-1}; //存放抽取到的姓名的序号
//初始化首元素为-1,避免出现第一次抽中第一个造成误判为抽到重复序号
int i = 0, num = 0;
int l, m = 1;
bool repeat = false; //抽到重复序号的标志位
if ((fp = fopen(argv[1], "r")) == NULL) //打开目标文件
{
printf("Fail to open file!\n");
}
while (fgets(str[i], 20, fp) != NULL) //读取名单,并存在数组中
{
if (str[i][strlen(str[i]) - 1] == '\n')
{
str[i][strlen(str[i]) - 1] = '\0';
}
i++;
}
printf("请输入要抽取的个数:\n");
scanf("%d", &l);
while (m <= l)
{
t = time(NULL);
srand(t);
repeat = false;
for (int j = 100000; j > 0; j -= 10000)
{
k = rand() % i;
fprintf(stderr, "%s\r", str[k]);
usleep(j);
}
for (int j = 500000; j > 0; j -= 100000)
{
k = rand() % i;
fprintf(stderr, "%s\r", str[k]);
usleep(j);
}
for (int i = 0; i < m; i++) //因为是随机数,避免抽取到重复序号
{
if (targetname[i] == k)
repeat = true;
}
if (repeat)
continue;
printf("抽到的第%d个是:%s\n", m, str[k]);
targetname[m - 1] = k;
sleep(1);
for (int j = 0; j < 20; j++)
{
s2[m - 1][j] = str[k][j];
}
m++;
}
printf("本次共抽取了%d个人,他们分别是:\n", m - 1);
for (int i = 0; i < m - 1; i++)
{
printf(" %s \n", s2[i]);
}
fclose(fp);
return 0;
}
感兴趣的朋友们还可自行添加一些新功能,我就继续下副本了
版权声明:本文为m0_73440948原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。