问答题
试题四(15 分,每空3 分)
阅读以下说明和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.排名时,完成题目数量多者排名靠前;若完成的题目数相同,则用时少者排名靠前;若完成的题目数和所用时间均相等,则名次相同;完成题目数为0 的选手不参加排名。
函数void Statistic() 的功能是:读取输入数据,进行统计、排名并输出结果。
#define MAXN 300
typedef struct {
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,MaxIndex;
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) MaxIndex = k;
}/*while*/
for(i=1; i 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*/
}/*Statistic*/
【参考答案】
(A)(h-I)*F0+m,及其等价形式(B)time+R[k].d[ch-‘a’]*B0其中ch-‘a’可以表示为ch......
(↓↓↓ 点击下方‘点击查看答案’看完整答案 ↓↓↓)