网友您好, 请在下方输入框内输入要搜索的题目:

题目内容 (请给出正确答案)

阅读以下说明和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<


参考答案

更多 “ 阅读以下说明和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 300typedef 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 ” 相关考题
考题 阅读以下应用说明及Visual Basic程序代码,将应填入(n)处的字句写在答题纸的对应栏内。应用说明某单位举办了一场知识竞赛,有300名选手参加竞赛,依次从1~300为选手编号。竞赛时间为9:00~11:00。8道竞赛题目依次从“A”~“H”编号,选手可按任意次序答题,每完成一道题目,可立即提交答案。若答案正确(Y),则选择其他题目进行解答,否则,可继续做该题目或选择其他题目进行解答,直至竞赛结束。选手提交答案的情况及判定结果由专人即时录入,录入数据包括提交答案的时间、选手编号、题目编号(A~H)、是否正确(Y/N)。对竞赛情况进行统计和排名的规则如下:1.若选手X在竞赛时提交的题目P解答正确,则解答该题目所用时间如下计算:解答题目P的用时=提交题目P正确的时间-竞赛的开始时间+罚时罚时;提交题目P错误解答的次数×20例如:设14号选手在10:27提交了题目A的正确解答,则该选手正确解答该题目所用时间为87分钟,由于他在09:37和09:52两次提交了题目A的错误解答,因此罚时为2×20=40分钟,所以14号选手解答题目A的用时=87+40=127(分钟)。2.已经提交正确答案的题目再次提交时不再计算。3.竞赛结束时,选手的总用时为所有解答正确的题目用时累加所得,解答不正确的题目不计时。4.排名时,完成题目数量多者排名靠前;若完成的题目数相同,则用时少者排名靠前:若完成的题目数和所用时间均相等,则名次相同;完成题目数为0的选手不参加排名。本应用程序的运行窗口如下图所示:窗口中的两个文本框为Txt_time和Txt_player,分别用于录入提交答案的时间和选手编号。组合列表框Combol提供题目编号(A~H),录入时从中选择。检查框Chk yn用于输入解答是否正确信息。当单击“确定”按钮(Cmd_comfirrn)时,录入的提交信息加入组合列表框Listl中,排名情况在列表框List2输出。单击“关闭”按钮时退出应用程序。在开发过程中,需要编写的部分程序代码如下:程序代码Private Tyve Infono As Integer '选手编号hum As Integer '完成的题目数量time As Integer '完成题目的总用时d(8) As Integer 'd[i]用于记录提交第i个题目错误答案的次数a(8) As Boolean 'aC[i]用于记录第i个题目是否已经提交正确答案End TypeDim R(301) As Info 'R[j]用于统计编号为j的选手提交答案的情况Dim Maxlndex As Integer 'MaxIndex记录提交答案的选手中编号最大者Private Sub Form_Load()For i=1 To 8Combol.Addltem Chr( (1) )NextCombol.Text = Combol.List(0): Txt_time. Text= "": Txt_player. Text= ""For i = 1 To 300R(i).num=0: R(i).time = 0: R(i).no = IForj = 1 To 8R(i).d(j) = 0: R(i).a(j) = FalseNext j, iEnd SubPrivate Sub Crud_confirm_Click()Dimh, m, k, time As Integer, ch, pass, sl As Stringk = InStr(Txt_time.Text, ":"): If k < 2 Then GoTo errorlh = Val(Left(Txt_time. Text, k - 1 )): m = Val(Mid(Txt_time. Text, k + 1 ))Ifh > 11 Or h = 11 And m > 0 Or m >= 60 Then GoTo errorltime=(2) '计算答题时间,以分钟为单位If Txt player. Text < 1 Or Txt_player. Text> 300 Then GoTo errorlch=(3) '取题目编号pass = llf(Chk_yn. (4)= 0, "N", "Y")s1 = Txt__time. Text+ Space(4)+ Txt_player. Texts1 = s1 + Space(10 - Len(Txt_player. Text))+ ch + Space(8) + passListl .Addltem s1k = Val(Txt_player. Text) 'k为选手编号R(k).no = k '编号为K的选手的提交信息记录在下标在K的数组元素中If k > Maxlndex Then Maxlndex = km = Asc(ch) - Ase("A")Ifpass <> "Y" Then '编号为K的选手提交第m个题目的解答不正确R(k).d(m) = R(k).d(m) + 1Elself R0(k).a(m) <> True Then '已经提交正确的题目的解答不再计算R(k).a(m) = True: R(k).num = R(k).num + IR(k).time = R(k).time +(5)Call Statistic '调用过程 Statistic 进行实时排名和输出End IfExit Suberrorl: MsgBox "录入信息有误!", vbOKOnlyEnd Sub

考题 阅读以下说明及Visual Basic程序代码,将应填入(n)处的字句写在对应栏内。【说明】某学校举办了一场奥运知识竞赛,参加竞赛的选手为200名,1~200为选手编号。竞赛时间为9:00~11:00。8道竞赛题目依次从“A”~“H”编号,选手可按任意次序答题,每完成一道题目,可立即提交答案。若答案正确(Y),则选择其他题目进行解答,否则,可继续做该题目或选择其他题目进行解答,直至竞赛结束。选手提交答案的情况及判定结果由专人即时录入,录入数据包括提交答案的时间、选手编号、题目编号(A~H)、是否正确(Y/N)等。对竞赛情况进行统计和排名的规则如下:1.若选手X在竞赛时提交的题目P解答正确,则解答该题目所用时间计算如下:解答题目P的用时=提交题目P正确的时间-竞赛的开始时间+罚时,罚时=提交题目P错误解答的次数×20例如:表1中14号选手在10:27提交了题目A的正确解答,因此该选手正确解答该题目所用时间P为87分钟,由于他在09:37和09:52两次提交了题目A的错误解答,因此罚时为(2×20)分钟=40分钟,所以14号选手解答题目A的用时=(87+ 40)分钟:127分钟。2.已经提交正确答案的题目再次提交时不再计算。3.竞赛结束时,选手的总用时为所有解答正确的题目用时累加所得,解答不正确的题目不计时。4.排名时,完成题目数量多者排名靠前;若完成的题目数相同,则用时少者排名靠前;若完成的题目数和所用时间均相等,则名次相同;完成题目数为。的选手不参加排名。本应用程序的运行窗口如图3所示。窗口中的两个文本框为Txt_time和Txt_player,分别用于录入提交答案的时间和选手编号。组合列表框Combo1提供题目编号(A~H),录入时从中选择。检查框Chk_yn用于输入解答是否正确信息。当单击“确定”按钮(Cmd_comfirm)时,录入的提交信息加入列表框List1中,排名情况在列表框List2输出。单击“关闭”按钮时退出应用程序。在开发过程中,需要编写的部分程序代码如下:【程序】Private Type infoNo As Integer ′选手编号Num As Integer ′完成题目数量Time As Integer ′完成题目的总用时d(8)As Integer ′d用于记录提交第i个题目错误答案的次数a(8)As Boolean ′a用于记录第i个题目是否已经提交正确答案End TypeDim R(201)As info ′R[j]用于统计编号为j的选手提交答案的情况Dim Maxlndex As Integer ′Maxlndex记录提交答案的选手中编号最大者Private Sub Form_Load()For i = 1 to 8Combo1. Addltem chr((1))NextCombo1. Text = Combo1. List(0):txt_time.Text =" ":txt_player.Text =" "For i = 1 To 200R(i) num=0:R(i).time =0:R(i).no=iForj = 1 To 8R(i).d(j) =0:R(i).a(j) =FalseNext j,iEnd SubPrivate Sub cmd_confirm_Click()Dim h, m, k, time As Integer, ch, pass, s1 As StringK = Instr(txt_time, text,": "):If k<2 Then Goto error1H = Val(Left(txt_time. Text, k-1)):m = Val(Mid(txt_time. Text, k+1))If h>11 Or h=11 And m>0 Or m>=60 Then goto errorlTime=(2) ′计算答题时间,以分钟为单位If txt_plater, text<1 or txt_player, text>200 Then Goto errorlch=(3)pass = IIf(chk_yn.(4)=0,"N" ,"Y")s1 = txt_time. Text+Space(4) + txt_player. Texts1 = s1 + Space(10 - Len(txt_player. Text))+ch+Space(8)+passList1. Additem s1K = Val(txt_player. Text) ′k为选手编号R(k). no =k ′编号为k的选手的提交信息记录在下标为k的数组′元素中If k>maxindex Then maxindex = kM =Asc(ch)-Asc("a")If pass< >"Y" Then ′编号为k的选手提交第m个题目的解答不正确R(k).d(m)=R(k).d(m)+1Else If R(k).a(m)< >True Then ′已经提交正确的题目的解答不再计算R(k).a(m) =true:R(k).num=R(k).num+1R(k).time = R(k). time +(5)Call statistic ′调用过程statistic进行实时排名和输出End IfExit Suberror1: MsgBox "录入信息有错误!" ,vbOKOnlyEnd Sub

考题 ●试题二阅读下列函数说明和C代码,将应填入(n)处的字句写在答题纸的对应栏内。【说明】该程序运行后,输出下面的数字金字塔【程序】includestdio.hmain (){char max,next;int i;for(max=′1′;max=′9′;max++){for(i=1;i=20- (1) ;++i)printf(" ");for(next= (2) ;next= (3) ;next++)printf("%c",next);for(next= (4) ;next= (5) ;next--)printf("%c",next);printf("\n");}}

考题 ●试题七阅读以下说明及Visual Basic程序代码,将应填入(n)处的字句写在答题纸的对应栏内。【说明】某学校举办了一场奥运知识竞赛,参加竞赛的选手为200名,1~200为选手编号。竞赛时间为9:00~11:00。8道竞赛题目依次从"A"~"H"编号,选手可按任意次序答题,每完成一道题目,可立即提交答案。若答案正确(Y),则选择其他题目进行解答,否则,可继续做该题目或选择其他题目进行解答,直至竞赛结束。选手提交答案的情况及判定结果由专人即时录入,录入数据包括提交答案的时间、选手编号、题目编号(A~H)、是否正确(Y/N)等。对竞赛情况进行统计和排名的规则如下:1.若选手X在竞赛时提交的题目P解答正确,则解答该题目所用时间计算如下:解答题目P的用时=提交题目P正确的时间-竞赛的开始时间+罚时罚时=提交题目P错误解答的次数×20例如:表1中14号选手在10:27提交了题目A的正确解答,因此该选手正确解答该题目所用时间P为87分钟,由于他在09:37和09:52两次提交了题目A的错误解答,因此罚时为(2×20)分钟=40分钟,所以14号选手解答题目A的用时=(87+40)分钟=127分钟。2.已经提交正确答案的题目再次提交时不再计算。3.竞赛结束时,选手的总用时为所有解答正确的题目用时累加所得,解答不正确的题目不计时。4.排名时,完成题目数量多者排名靠前;若完成的题目数相同,则用时少者排名靠前;若完成的题目数和所用时间均相等,则名次相同;完成题目数为0的选手不参加排名。本应用程序的运行窗口如图3所示。图3窗口中的两个文本框为Txt_time和Txt_player,分别用于录入提交答案的时间和选手编号。组合列表框Combol提供题目编号(A~H),录入时从中选择。检查框Chk_yn用于输入解答是否正确信息。当单击"确定"按钮(Cmd_comfirm)时,录入的提交信息加入列表框Listl中,排名情况在列表框List2输出。单击"关闭"按钮时退出应用程序。在开发过程中,需要编写的部分程序代码如下:【程序】Private Type InfoNo As Integer′选手编号Num As Integer′完成题目数量Time As Integer′完成题目的总用时d (8) As Integer′d用于记录提交第i个题目错误答案的次数a (8) As Boolean′a用于记录第i个题目是否已经提交正确答案End TypeDim R(201)As info′R[j]用于统计编号为j的选手提交答案的情况Dim MaxIndex As Integer′MaxIndex记录提交答案的选手中编号最大者Private Sub Form_Load()For i=1 to 8Combo1.AddItem chr( (1) )NextCombo1.Text=Combo1.List(0):txt_time.Text="":txt_player.Text=""For i=1 To 200R(i).num=0:R(i).time=0:R(i).no=iForj=1 To 8R(i).d(j)=0:R(i).a(j)=FalseNext j,iEnd SubPrivate Sub cmd_confirm_Click()Dim h,m,k,time As Integer,ch,pass,s1 As StringK=Instr(txt_time.text,"∶"):If k2 Then Goto error1H=Val(Left(txt_time.Text,k-1)):m=Val(Mid(txt_time.Text,k+1))If h11 Or h=11 And m0 Or m=60 Then goto errorlTime= (2) ′计算答题时间,以分钟为单位If txt_plater.text1 or txt_player.text200 Then Goto error1ch= (3)pass=IIf(chk_yn. (4) =0,"N","Y")s1=txt_time.Text+Space (4) +txt_player.Texts1=s1+Space(10-Len(txt_player.Text))+ch+Space (8) +passList1.Additem s1K=Val(txt_player.Text)′k为选手编号R(k).no=k′编号为k的选手的提交信息记录在下标为k的数组元素中If kmaxindex Then maxindex=kM=Asc(ch)-Asc("a")If pass"Y"Then′编号为k的选手提交第m个题目的解答不正确R(k).d(m)=R(k).d(m)+1Else If R(k).a(m)True Then′已经提交正确的题目的解答不再计算R(k).a(m)=true:R(k).num=R(k).num+1R(k).time=R(k).time+ (5)Call statistic′调用过程statistic进行实时排名和输出End IfExit Suberror1:MsgBox"录入信息有错误!",vbOKOnlyEnd Sub

考题 试题三(共 15 分)阅读以下说明和 C 程序,将应填入 (n) 处的字句写在答题纸的对应栏内。

考题 阅读下列说明和C++-代码,将应填入(n)处的字句写在答题纸的对应栏内。 【说明】 某发票(lnvoice)由抬头(Head)部分、正文部分和脚注(Foot)部分构成。现采用装饰(Decorator)模式实现打印发票的功能,得到如图5-1所示的类图。 【C++代码】 #include using namespace std; class invoice{ public: (1){ cout

考题 阅读下列说明,补充(1)-(9),将解答填入答题纸的对应栏内。

考题 阅读下列说明和Java代码,将应填入(n)处的字句写在答题纸的对应栏内。【说明】 某文件管理系统中定义了类OfficeDoc和DocExplorer,当类OfficeDoc发生变化时,类DocExplorer的所有对象都要更新其自身的状态,现采用观察者(Observer)设计模式来实现该需求,所设计的类图如图6-1所示。

考题 阅读下列说明和?C++代码,将应填入(n)处的字句写在答题纸的对应栏内。 【说明】 阅读下列说明和?Java代码,将应填入?(n)?处的字句写在答题纸的对应栏内。 【说明】 某快餐厅主要制作并出售儿童套餐,一般包括主餐(各类比萨)、饮料和玩具,其餐品种 类可能不同,但其制作过程相同。前台服务员?(Waiter)?调度厨师制作套餐。现采用生成器?(Builder)?模式实现制作过程,得到如图?6-1?所示的类图。