1、三级数据库技术机试-308 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.对 10个候选人进行选举,现有一个 100条记录的选票数据文件 IN29.DAT,其数据存放的格式是每条记录的长度均为 10位,第一位表示第一个人的选中情况,第二位表示第二个人的选中情况,依次类推。每一位内容均为字符 0或 1,1 表示此人被选中,0 表示此人未被选中,若一张选票选中人数小于等于 5个人时则被认为是无效的选票。给定函数 ReadDat()的功能是把选票数据读入到字符串数组 xx中。请编制函数 CountRs()来统计每个人的选票数并把得票数依次存入
2、yy0到 yy9中,最后调用函数 WriteDat()把结果 yy输出到文件 OUT29.DAT中。注意:部分源程序已给出。请勿改动主函数 main()、读函数 ReadDat()和写函数 WriteDat()的内容。试题程序:#include stdio.hchar xx100 11;int yy10;int ReadDat (void);void WriteDat(void);void CountRs(void)main ( )int i;for (i=0; i10; i+)yyi = 0;if (ReadDat ( ) )print f (“选票数据文件 IN29. DAT不能打开! /
3、007 /n“);return;CountRs ( );WriteDat ();int ReadDat (void)FILE *fp;int i;char tt13;if(fp = fopen(“IN29.DAT“, “r“) = NULL)return 1;for (i = 0; i 100; i+)if(fgets(tt, 13, fp) = NULL)return 1;memcpy(xxi, tt, 10);fclose (fp);return 0;void WriteDat(void)FILE *fp;int i;fp = fopen(“OUT29.DAT“, “w“);for(i =
4、 0; i 10; i+)fprintf(fp, “%dkn“, yyi);printf(“第%d 个人的选票数=%d/n“, i+1, yyi);fclose(fp);(分数:100.00)_三级数据库技术机试-308 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.对 10个候选人进行选举,现有一个 100条记录的选票数据文件 IN29.DAT,其数据存放的格式是每条记录的长度均为 10位,第一位表示第一个人的选中情况,第二位表示第二个人的选中情况,依次类推。每一位内容均为字符 0或 1,1 表示此人被选中,0 表示此人未被选中,若一张选
5、票选中人数小于等于 5个人时则被认为是无效的选票。给定函数 ReadDat()的功能是把选票数据读入到字符串数组 xx中。请编制函数 CountRs()来统计每个人的选票数并把得票数依次存入 yy0到 yy9中,最后调用函数 WriteDat()把结果 yy输出到文件 OUT29.DAT中。注意:部分源程序已给出。请勿改动主函数 main()、读函数 ReadDat()和写函数 WriteDat()的内容。试题程序:#include stdio.hchar xx100 11;int yy10;int ReadDat (void);void WriteDat(void);void CountRs
6、(void)main ( )int i;for (i=0; i10; i+)yyi = 0;if (ReadDat ( ) )print f (“选票数据文件 IN29. DAT不能打开! /007 /n“);return;CountRs ( );WriteDat ();int ReadDat (void)FILE *fp;int i;char tt13;if(fp = fopen(“IN29.DAT“, “r“) = NULL)return 1;for (i = 0; i 100; i+)if(fgets(tt, 13, fp) = NULL)return 1;memcpy(xxi, tt,
7、 10);fclose (fp);return 0;void WriteDat(void)FILE *fp;int i;fp = fopen(“OUT29.DAT“, “w“);for(i = 0; i 10; i+)fprintf(fp, “%dkn“, yyi);printf(“第%d 个人的选票数=%d/n“, i+1, yyi);fclose(fp);(分数:100.00)_正确答案:(void CountRs(void)int i, count, j;char*pf;for(i=0; i10;i+)yyi=0; /*给数组 YY初始化置 0*/for(i=0; i100; i+)pf
8、=xxi; count=0; /*使指针 pf指向各行的首地址*/while (*pf)if(*pf=1)count+; /*统计得票数 count*/pf+;else pf+;if(count5) /*当 count值大于 5时为有效票数*/pf=xxi; /*使指针 Pf指向该行的首地址*/j=0;while(*pf) /*统计每个人的得票数,并依次存入 yy0到 yy9*/if (*pf=1)yyj+=1;j+;pf+;else if (*pf=0)pf+;j+;)解析:解析 根据题意可知,本题涉及到了一个二维字符数组,该数组中含有 100条记录,每条记录又包括长度为 10位的字符串,并且该字符串中的字符只含有“0” (表示未选中)和“1” (表示选中)两个字符(用来标识某人的被选中情况)。本题要求要统计每个人的选票数,也就是要统计每行中字符为“1”的个数,来借助一个指向字符指针的变量 pf,首先让该指针指向各行的首地址,然后按照行方向依次指向当前行的各个字符,每找到一个字符就对它进行条件判断:看其是否为“1”,如果为“1”,则给用来统计得票数的变量 count加 1。当 count值大于 5时(选票中选中人数小于等于 5个人时则被认为是无效选票),我们才做把得票数依次存入 yy0到 yy9中。注意,在 yy数组中的每一项都存的是一个得票的总数。