中易网

c++的歌手比赛系统

答案:2  悬赏:40  
解决时间 2021-11-16 07:49
#include "stdio.h"
#include "stdlib.h"
#include "time.h"
#include "string.h"
#define N 100
#define M 10
int add = N-1;
int sum[N]={0},Max[N],Min[N];
float aver[N]={0};
struct player
{int num;
char name[8];
int score[M];
}a[N];
void Inistplayer(struct player a[],int n)
{int i;
printf("输入3个选手编号,姓名,(用空格隔开)\n");
for(i=0;iscanf("%d %s",&a[i].num,a[i].name);
}
void Inputscore(int score[],int n)
{int i;
for(i=0;iscanf("%d
}
void sort(struct player a[],float b[],int n)
{int i,k,j,t;
float temp;
char str[8];
for(i=0;i{k=i;
for(j=i+1;jif(b[k]>b[j]) k=j;
if(k!=i)
{temp=b[i];
b[i]=b[k];
b[k]=temp;
strcpy(str,a[i].name);
strcpy(a[i].name,a[k].name);
strcpy(a[k].name,str);
t=a[i].num;
a[i].num=a[k].num;
a[k].num=t;
}
}
} void save()
{FILE *fp;
int i;
if((fp=fopen("stu_list","wb"))==NULL)
{printf("cannot open file\n");
return;
}
for(i=0;iif(fwrite(&a[i],sizeof(struct player),1,fp)!=1)
printf("file write error\n");
fclose(fp);
}
main()
{int flag=1,n,i,m,j;
struct player a[N];
printf("**********1.输入选手数据***********\n");
printf("**********2.评委打分***************\n");
printf("**********3.成绩排序***************\n");
printf("**********4.数据查询***************\n");
printf("**********5.追加学生数据***********\n");
printf("**********6.写入数据文件***********\n");
printf("**********7.退出系统***************\n");
while(flag)
{printf("你想进行的操作:");
scanf("%d",&n);
switch(n)
{
case 1:Inistplayer(a,N);break;
case 2:srand((unsigned)time(NULL));
for(i=0;i{
printf("%d位选手的成绩:",i+1);
Inputscore(a[i].score,M);
for(j=0;jprintf("%d ",a[i].score[j]);
printf("\n");
}
break;
case 3:for(i=0;i{Max[i]=a[i].score[0];
Min[i]=a[i].score[0];
for(j=0;j{
sum[i]+=a[i].score[j];
if(Max[i]if(Min[i]>a[i].score[j]) Min[i]=a[i].score[j];
}
aver[i]=(float)(sum[i]-Max[i]-Min[i])/(M-2);
}
sort(a,aver,N);
for(i=0;iprintf("%s %5.2f\n",a[i].name,aver[i]);
break;
case 4:printf("你想查询选手的数据:(编号)");
scanf("%d",&m);
for(i=0;iif(a[i].num==m)
{
printf("%d号选手%s总分:%d,最高分%d,最低分%d,平均分%5.2f",a[i].num,a[i].name,sum[i],Max[i],Min[i],aver[i]);
printf("\n");
}
break;
case 5:printf("请输入要追加的选手数据:\n");
add += 1;
scanf("%d %s",&a[add].num,&a[add].name);
break;
case 6:save();
printf("写入完成\n");
break;
case 7: printf("谢谢使用。");
exit(0);
break;
default:flag=0;
}
}return 0;
}
求完善啊..不是3个人 而是自己想输入多少就是多少..
最佳答案
你的意思是让选手的数量可以灵活的变动吧,如果是这样的话,你应该使用链表,不要用数组,如果你用结构体的话,就这样:
struct player
{int num;
char name[8];
int score[M];
struct player *next;

}
当创建一个歌手时将这个歌手的地址交给上一个歌手个*next,并记下第一个歌手的地址
这样就可以灵活变动歌手的数量了。查找、排序时依次用*next访问下一个来实现。

还可以使用class,建一个PlayerLink类,在里边添加歌手,向上边一样组成链表,所有的方法以类方法的形式实现。

——正在学习,多多指教
全部回答
//include////////////// #include "stdio.h" #include //define//////////////////// #define long 20 //global//////////////////////////// int id,x,y[10],a,i,flag,what,remove = 0; //存放id,mark,ave, i用于循环,flag是循环标志 //remove用于存放弃掉最高分和最低分后的统计值 char n,name; //存放name sum=0,aver=0, flag = 1; //function////////////////////////define singer's message///////// //singer 里面的参数分别代表:编号,姓名,选手的平均成绩,总成绩 void singer() { id = x; //id 初始化 name = n; //名字初始化 printf("选手id:%d\n",id); //singer 函数仅用于输出 }//这里设置一个手动打分,要求你输入分数的,当然也可以随机,用random函数就可以了 void ping() { int j,sorce[10]; //i 用于循环,sum用于统计总成绩,aver用于统计平均成绩 int max,min; //存放最高和最低分, printf("请输入10个评委打的分数:\n"); for(i=0;i<10;i++) { scanf("%d",&sorce[i]); //总成绩 sum += sorce[i]; } //平均成绩算法 //弃掉最高和最低分 for(i = 0;i<10;i++) { for(j = i;j<10;j++) { max = min = sorce[0]; //先假设max和min得值 if(sorce[i]
我要举报
如以上问答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯