首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
阅读以下应用程序说明和C程序,将C程序段中(1)~(6)空缺处的语句填写完整。 【说明】 某大学征询学生意见,从各学院预选的n(n≤60)位优秀大学生中,评选出“十佳大学生”。以下【C程序】对各位学生选票进行相关的统计、排序等处理。 (1
阅读以下应用程序说明和C程序,将C程序段中(1)~(6)空缺处的语句填写完整。 【说明】 某大学征询学生意见,从各学院预选的n(n≤60)位优秀大学生中,评选出“十佳大学生”。以下【C程序】对各位学生选票进行相关的统计、排序等处理。 (1
admin
2009-02-15
68
问题
阅读以下应用程序说明和C程序,将C程序段中(1)~(6)空缺处的语句填写完整。
【说明】
某大学征询学生意见,从各学院预选的n(n≤60)位优秀大学生中,评选出“十佳大学生”。以下【C程序】对各位学生选票进行相关的统计、排序等处理。
(1)各学院预选的优秀大学生按1,2,…顺序连续编号,每个编号用两个字符表示,即01,02,…。
(2)所回收的选票按以下格式存于文件source中,每行字符串对应一张选票。其中,姓名占10个字符,学院名称占30个字符,大学生编号占20个字符。
(3)对应名次的大学生编号可以有空缺,但必须用00表示。
(4)若编号超出规定范围,或编号重复出现,按照废票处理。
(5)按选票中所列“十佳大学生”顺序给出各名大学生的得分。评分标准如下:
一 二 三 四 五 六 七 八 九 十
15 12 9 7 6 5 4 3 2 1
(6)按各位大学生得分数由高到低顺序排队,并按以下格式列出“十佳大学生”排行表。
名次 大学生编号 合计得分 合计得票数
若得分相同,则得票数多的在前;若得分和得票数都相同,则编号小的在前。
以下【C程序】中所应用到的函数fopen、fclose和fgets都是I/O程序库中的函数。
【C程序】
#include <stdio. h>
#define n 60
long int tn[n], td[n], score[n+1][10], order[n];
char s[80];
int mark[]=(15,12,9,7,6,5,4,3,2,1);
FILE *fp, *fopen();
Main()
{ int c, g, k, I, j, b[10];
long int e, d, t, tt, dd;
char * p;
for(i=0; i<=n; i++)
for(j=0; j<10; j++)
score
[j]=0;
fP=fopen("source", "r"); /*以读方式打开文件source*/
p=fgets(s, 80, fp); /*读fp所指文件的下一行字符串于s*/
while(*p){
g=l; k=0; p+=40;
while(k<10){
c=((*p++)-’0’)*10+((*p++)-’0’);
b[k++]=c)
if(c<=n){
if(c)
{ i=0;
While( (1) );
If( (2) ){g=0; break;}
}
else{g=0; break;}
}
If(g)
For(i=0; i<k; i++)
If(b
)
(3);
p=fgets(s, 80, fP);
}
Fclose(fp); /*关闭fp所指文件*/
For(i=1; i<n; i++){
For(t=0, d=0, j=0; j<10; j++){
t +=(e=score
[j]);
d +=e * mark[j];
}
tn[i-1]=t; td[i-1]=d; order[i-1]=i;
}
For(i=0; i<n-1; i++){
k=i;
for(j=i+1; j<n; j++)
if((t=td[order[j]-1])>(d=td[order[k]-1]))
k=j;
else
if(t==d){
tt=(4);
dd=(5);
for(c=0; c<10; c++)
if((e=(6))>0){
k=j; break;}
else
if(e<0)break;
}
If(k!=i){
t=order[k]; order[k]=order
; order
=t;
}
}
For(i=0; i<10; i++)
Printf("%2d%2d%d%d\n", i+1, order
, td[order
-1], tn[order
-1]));
}
}
选项
答案
(1)c!=b[i++],或其他等价形式 (2)i<k,或其他等价形式 (3)score[b[i]][i]++,或其他等价形式 (4)order[j] (5)ordcr[k] (6)score[tt][c]-score[dd][c]
解析
仔细阅读本试题的程序说明和【C程序】后,可得出评选“十佳大学生”的数据格式和算法。该C程序先读入一行字符,进行合法性检查后再进行选票统计;读入所有选票后,再计算每个大学生的得分和选票数,最后进行排序输出。
通常,阅读一个C程序时,应先明白程序中所用变量的含义,这对解题是很有帮助的。程序中所用变量的含义,除了可在程序说明中了解之外,还可以通过程序中的输入/输出语句来获知。对照程序说明中给出的输出次序可以了解到,数组order是用来存放第i名大学生的编号,数组td用来存放大学生的总分,数组tn用来存放大学生得到的选票总数。
程序中用while(*p){...}语句所包含的程序段进行合法性检查并进行统计。合法性检查即排除非法的选票。指针p用于表示每次读入的一行80个字符的首地址,语句“p+=40”使p指向每张选票的第40个字符,把每张选票上的大学生编号转换成十进制数c,并存入数组b中。由于每张选票最多可选十名,因此需用k<10来进行循环控制。
由于(1)、(2)空缺处位于while(*p){...}的内循环中,且由语句“g=0; break;”(即变量g为0时跳出该循环)和语句“if(g)”可知,譬为合法性标记,因此(1)、(2)空缺处所填写的语句完成选票的合法性检查。由于非法选票有“编号超出规定范围”和“编号重复出现”两种,因此应当把当前编号c和已处理过的编号b
(i=0...k-1)进行比较,从而来判断是否满足“编号超出规定范围”,即(1)空缺处应填入“c!=b[i++]”。另外,当前编号c已存放在第k个字符中,当i小于k时,即表示有编号重复,因此(2)空缺处应填入“i<k”。
(3)在空缺处的“for(i=0; i<k; i++)”循环程序段中,数组b
表示编号为b
的大学生,在该张选票上被评为i+1名;数组score[b
]
表示编号为b
的大学生,被评为i+1名的选票有score[b
]
张。当一张选票上的10个编号都合法时,则应把该选票上的数据存入数组score中,即对编号为b
的大学生所得的第i+1名选票加1,因此(3)空缺处应填入“score[b
]
++”。
“fclose(fp);”之后的语句是对大学生的得分进行统计工作,其结果分别存放在大学生编号数组Order、选票总数变量tn和总分变量td中,然后进行排序。由语句的结构可知,用变量k标记得分最高的位置,即编号为order[k]的大学生得分为本次排序中最高,然后在外层for循环中进行条件交换,由此可知,该排序采用的是选择排序算法。
在排序过程中如果得分相同,即程序中条件“if(t==d)”成立,则必须根据两名大学生的得票情况进行排序,得分名次在前、票数多者排在前面。(6)空缺处所填写的语句是对得票数相同的情况进行排序处理,e为控制变量,用来存放编号为Order[j]和Order[k]的相同名次的得票数的比较结果,并根据该比较结果确定是否进行位置交换。因此(4)空缺处所填写的内容是“order[j]”;(5)空缺处所填写的内容是“order[k]”;(6)空缺处所填写的内容是“score[tt][c]—score[dd][c]”,即编号为j的大学生与编号为k的大学生的得票数之差。
转载请注明原文地址:https://kaotiyun.com/show/uojZ777K
本试题收录于:
程序员下午应用技术考试题库软考初级分类
0
程序员下午应用技术考试
软考初级
相关试题推荐
以下关于数据可视化展现的叙述中,不正确的是_______。
下面不属于软件开发过程的是______。
以下关于计算机操作系统的叙述中,不正确的是(18)。
字符串编辑有3种基本操作:在指定位置插入一个字符、在指定位置删除一个字符、在指定位置用另一个字符替换原来的字符。将字符串ABCDE,编辑成ECDFE,至少需要执行(6)次基本操作。
Windows7系统运行时,用户用鼠标右击某个对象经常会弹出________________。
________________不属于移动终端设备。
Word2010中的格式刷可用于复制段落的格式,若要将选中的当前段落格式重复应用多次,应()。
___________接口是目前微机上最流行的I/O接口,具有支持热插拔、连接灵活、独立供电等优点,可以连接常见的鼠标、键盘、打印机、扫描仪、摄像头、充电器、闪存盘、MP3机、手机、数码相机、移动硬盘、外置光驱、Modem等几乎所有的外部设备。
在Excel中,设单元格A1中的值为100,B1中的值为200,A2中的值为300,B2中的值为400,若在A3单元格中输入函数“=SUM(A1:B2)”,按回车键后,A3单元格中的值为()。
______不属于企业信息系统存在的问题。
随机试题
A、Ignoringtheproblemtoavoidcausinganythingunpleasant.B、Tryingtofindaroommatewhoisconsiderateandcareful.C、Being
泄泻的治疗原则是()(2008年第67题)
轻度烧伤患者的创面处理,下列哪项错误?
急性胰腺炎一般在起病后几小时血清淀粉酶开始升高
最可能的诊断是该患儿的病理转变最严重的是
.下列室外排水管道与检查井关系的表述中()错误。
下列项目占有的资金属于不变资金的有()。
完善教师道德激励机制是教师道德建设的关键。()
风吹弯了路旁的树木,撕碎了店户的布幌,揭净了墙上的报单,遮昏了太阳,唱着,叫着,吼着,回荡着;忽然直弛,像惊狂了的大精灵,扯天扯地的疾走;忽然慌乱,四面八方的乱卷,像不知怎样好而决定乱撞的恶魔:忽然横扫,乘其不备的袭击着地上的一切,扭折了树枝,吹掀了屋瓦,
设A为三阶实对称矩阵,且存在可逆矩阵P=.(1)求a,b的值;(2)求正交变换x=Qy,化二次型f(x1,x2,x3)=XTA*x为标准形,其中A*为A的伴随矩阵;(3)若kE+A*合同于单位矩阵,求k的取值范围.
最新回复
(
0
)