1、三级数据库技术机试-253 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.对 10 个候选人进行选举,现有一个 100 条记录的选票文件 IN84.DAT,其数据存放格式是每条记录的长度均为 10 位,第一位表示第一个人的选中情况,第二位表示第二个人的选中情况,依此类推。每一位候选人的记录内容均为字符 O 或 1,1 表示此人被选中,0 表示此人未被选中,若一张选票选中人数大于 5个人时被认为无效的选票。给定函数 ReadDat()的功能是把选票数据读入到字符串数组 xx 中。请编制函数 CoutRs()来统计每个人的选票数并把得票数依次
2、存入 yy0到 yy9中,最后调用函数 WfiteDat()把结果”输出到文件 OUT84.DAT 中。注意:部分源程序已给出。请勿改动主函数 main()、读函数 ReadDat()和写函数 WfiteDat()的内容。试题程序:#includeStdiohchar xx10011;int YY10;int ReadDat(void);void WriteDat(void);void C0utRs(void)void main()int i;for(i=0;i10;i+)yyi=0;if(ReadDat()printf (“数据文件 IN84.DAT 不能打开! /n/007“ );retu
3、rn;CoutRs();.WriteDat();int ReadDat(void)FILE *fp;int i;char tt13;if(fp=fopen(“IN84.DAT“,“r“ )=NULL) return 1;for(i=0;i100;i+)if(fgets(tt,13,fp)=NULL) return 1;memcpy(xxi,tt,10);xxi 10=0;fclose(fp);return 0;void WriteDat)FILE *fp;int i;fp= foDen(“OUT84.DAT“,“w“);for(i=0;i10;i+)fprintf( fp, “%dkn“, y
4、y i );printf(,“第%d 个人的选票数=%d/n“, i+1,yy i );fclose(fp);(分数:100.00)_三级数据库技术机试-253 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.对 10 个候选人进行选举,现有一个 100 条记录的选票文件 IN84.DAT,其数据存放格式是每条记录的长度均为 10 位,第一位表示第一个人的选中情况,第二位表示第二个人的选中情况,依此类推。每一位候选人的记录内容均为字符 O 或 1,1 表示此人被选中,0 表示此人未被选中,若一张选票选中人数大于 5个人时被认为无效的选票。给定
5、函数 ReadDat()的功能是把选票数据读入到字符串数组 xx 中。请编制函数 CoutRs()来统计每个人的选票数并把得票数依次存入 yy0到 yy9中,最后调用函数 WfiteDat()把结果”输出到文件 OUT84.DAT 中。注意:部分源程序已给出。请勿改动主函数 main()、读函数 ReadDat()和写函数 WfiteDat()的内容。试题程序:#includeStdiohchar xx10011;int YY10;int ReadDat(void);void WriteDat(void);void C0utRs(void)void main()int i;for(i=0;i1
6、0;i+)yyi=0;if(ReadDat()printf (“数据文件 IN84.DAT 不能打开! /n/007“ );return;CoutRs();.WriteDat();int ReadDat(void)FILE *fp;int i;char tt13;if(fp=fopen(“IN84.DAT“,“r“ )=NULL) return 1;for(i=0;i100;i+)if(fgets(tt,13,fp)=NULL) return 1;memcpy(xxi,tt,10);xxi 10=0;fclose(fp);return 0;void WriteDat)FILE *fp;int
7、i;fp= foDen(“OUT84.DAT“,“w“);for(i=0;i10;i+)fprintf( fp, “%dkn“, yy i );printf(,“第%d 个人的选票数=%d/n“, i+1,yy i );fclose(fp);(分数:100.00)_正确答案:(void CoutRs (void)int i,count, j;char *pf;for (i=0; i10;i+)yyi =0; for (i=0; i100; i+)pf=xxi; /*指针 pf 指向字符串的第一个字符* /count=0;while (*pr)if (*Df= 1)count+; /*统计每条记
8、录中 1 的个数*/pf+;else pf+;if (count=5) /*如果每条记录中 1 的个数小于等于 5 则为有效票*/ pf=xx i; /*指针 pf 指向字符串的第一个字符*/j=0;while (*pf) /*统计每个人的选票数并把得票数依次存入 yy 0到 yy 9 中*/if (*pf=1)yyj+=1;j+;pf+;else if(*pf=0)j+;pf+;)解析:解析 本题考查的知识点如下:(1)二维数组的操作。(2)指向数组的指针。在本题中,要先判断选票是否有效。因为记录存放在一个二维数组中,为了简便我们为数组的一组元素定义一个指向该数组每一行数据的指针,例如,chaf*p=xx2。初始时该指针指向该行的第一个元素,指针地址每加 1,则指向下一个元素。这样就可以轻松地统计每一个选票。设一变量标记每一个选票中 1 的个数,若其不大于 5,则选票有效。若选票有效,则依次查看哪一个元素为 1,在数组”相应的元素上加 1。使用循环实现对所有记录的访问。