![](https://cos-cdn.shuashuati.com/pipixue-web/2020-1231-2005-12/ti_inject-812ce.png)
阅读以下说明和C代码,将应填入(n)处的字句写在答题纸的对应栏内。 说明 某单位举办了一场知识竞赛,参加竞赛的选手为300名,依次从1~300进行编号。竞赛时间为9:00~11:00。8道竞赛题目依次从“A”~“H”编号,选手可按任意次序答 题,每完成一道题目,可立即提交答案。若答案正确(Y),则选择其他题目进行解答,否则,可继续做该题目或选择其他题目进行解答,直至竞赛结束。 选手提交答案的情况及判定结果由专人即时录入,录入的数据如表1所示,对竞赛情况进行统计和排名的结果如表2所示。 统计和排名的规则如下: 1.若选手X在竞赛时提交的题目P解答正确,则解答该题目所用时间如下计算; 解答题目P的用时=提交题目P正确的时间-竞赛的开始时间+罚时 罚时=提交题目P错误解答的次数×20 例如=表1中14号选手在10:27提交了题目A的正确解答,因此该选手正确解答该题目所用时间为87分钟,由于之前的两次提交错误解答,罚2×20=40分钟,所以14号选手解答题目A的用时=87+40=127(分钟)。 2.已经提交正确答案的题目再次提交时不再计算。 3.竞赛结束时,选手的总用所有解答正确的题目用时累加所得,解答不正确的题目不计时。 4.排名时,完成题目数量多者排名靠前;若完成的题目数相同,则用时少者排名靠前;若完成的题目数和所用时间均相等,则名次相同;完成题目数为。的选手不参加排名。 函数void Statistic()的功能是:读取输入数据,进行统计、排名并输出结果。 define MAXN 300 typedef stmct{ int no; /*选手编号*/ int num; /*完成的题目数量*/ int time; /*完成题目的总用时*/ int d[8]; /*d[i]用于记录提交第i个题目错误答案的次数*/ int a[8]; /*a[i]用于记录第i个题目是否已经提交正确答案*/ }Info; void Statistic() { char ch,pass; int i,j,k,h,m,t,time,Maxlndex; Info R[MAXN+1 ]; for(i=1; i<=MAXN; i++){ /*数组R的元素置初值0*/ R[i].no = 0;R[i].num = 0; R[i].time = 0; for(j=0; j<8; j++) {R[i].d[j] = 0; R[i].a[j] = 0;} }/*for*/ MaxIndex = 0; while (1){ /*录入一名选手提交答案的信息(小时:分钟,选取手编号,题目号,是否正确)*/ scanf('%d:%d,%d,%c,%c',&h,&m,&k,&ch,&pass); if(h==0) break; R[k].no = k; /*k为选手编号码*/ time=(1); /*计算答题时间,以分钟为单位*/ if(isupper(ch)) ch = 'a' + ch- 'A'; if(pass != 'Y' && pass != 'y') {R[k].d[ch-'a']++; continue;} if (R[k].a[ch-'a']==1) continue; R[k].a[ch-'a'] = 1; R[k] .num++; R[k].time +=(2); if (k > MaxIndex) Maxlndex = k; }/*while*/ for(i=l; i<MaxIndex; i++) { /*选取择排序*/ for(t=i,j=i+1; j<=Maxlndex; j++) if(R[t].num<R[j].num|| (3))t=j; if((4)) {R[0]=R[t];R[t]=R[i];R[i]=R[0];} }/*for*/ k=1; R[0] = R[l]; for(i=1; i<=Maxlndex; i++) /*输出排名情况*/ if (R,[i].num > 0) { if(R[i].num!=R[0].num||R[i].time!=R[0].time) k++; R[0]=(5); printf('%d:%3d %4d %5d/n',k,R[i].no,R[i].num,R[i].time); )/*if*l<