1、三级数据库技术-530 及答案解析(总分:100.00,做题时间:90 分钟)一、设计与应用题(总题数:1,分数:100.00)1.对 10个候选人进行选举,现有一个 100条记录的选票数据文件 in.dat,其数据存放的格式是每条记录的长度均为 10位,第一位表示第一个候选人的选中情况,第二位表示第二个候选人的选中情况,依次类推;每一位内容均为字符 0或 1,1 表示此人被选中,0 表示此人未被选中,全选或全不选(空选票)均为无效的选票则不作统计。给定函数 ReadDat()的功能是把选票数据读入到字符串数组 xx中。请编制函数CountRs()来统计每个候选人的选票数并把得票数依次存入 y
2、y0到 yy9中,即第一个候选人的得票数存入 yy0中,以此类推。最后调用函数 WriteDat()把结果 yy输出到文件 out.dat中。 请勿改动主函数 main()、读函数 ReadDat()和输出函数 WriteDat()的内容。 #include stdio.h #include string.h char xx100 11; int yy10; int ReadDat (void); void WriteDat(void); void CountRs(void) void main () int i; for(i=0; i10; i+) yyi=0; if (ReadDat ()
3、 printf (“选票数据文件 in.dat不能打开!007n“); return; CountRs (); WriteDat (); /*把选票数据读入到字符串数组 xx中*/ int ReadDat (void) FILE *fp; int i; char tt13; if (fp=fopen (“in.dat“, “r“) ) =NULL) return 1; /如果文件 in.dat为空,则返回 1 /*把 100条记录的选票数据存入字符串数组 xx中*/ for(i=0; i100; i+) /*从文件 in.dat中读取长度为 12的字符串存入字符数组 tt中,如果其值为空,则返
4、回 1*/ if (fgets (tt, 13, fp) =NULL) return 1; memcpy(xxi, tt, i0); /把字符数组 tt中的 10个字符拷贝到数组 xxi中 xxi 10=0; /把 0赋给数组元素 xxi 10 fclose(fp); return 0; /*把结果 yy输出到文件 out.dat中*/ void WriteDat (void) FILE *fp; int i; fp=fopen(“out.dat“, “w“); for(i=0; i10; i+) fprintf(fp, “%dn“, yyi); printf(“第%d 个人的选票数=%dn“
5、, i+1, yyi); fclose(fp); (分数:100.00)_三级数据库技术-530 答案解析(总分:100.00,做题时间:90 分钟)一、设计与应用题(总题数:1,分数:100.00)1.对 10个候选人进行选举,现有一个 100条记录的选票数据文件 in.dat,其数据存放的格式是每条记录的长度均为 10位,第一位表示第一个候选人的选中情况,第二位表示第二个候选人的选中情况,依次类推;每一位内容均为字符 0或 1,1 表示此人被选中,0 表示此人未被选中,全选或全不选(空选票)均为无效的选票则不作统计。给定函数 ReadDat()的功能是把选票数据读入到字符串数组 xx中。请
6、编制函数CountRs()来统计每个候选人的选票数并把得票数依次存入 yy0到 yy9中,即第一个候选人的得票数存入 yy0中,以此类推。最后调用函数 WriteDat()把结果 yy输出到文件 out.dat中。 请勿改动主函数 main()、读函数 ReadDat()和输出函数 WriteDat()的内容。 #include stdio.h #include string.h char xx100 11; int yy10; int ReadDat (void); void WriteDat(void); void CountRs(void) void main () int i; for
7、(i=0; i10; i+) yyi=0; if (ReadDat () printf (“选票数据文件 in.dat不能打开!007n“); return; CountRs (); WriteDat (); /*把选票数据读入到字符串数组 xx中*/ int ReadDat (void) FILE *fp; int i; char tt13; if (fp=fopen (“in.dat“, “r“) ) =NULL) return 1; /如果文件 in.dat为空,则返回 1 /*把 100条记录的选票数据存入字符串数组 xx中*/ for(i=0; i100; i+) /*从文件 in.
8、dat中读取长度为 12的字符串存入字符数组 tt中,如果其值为空,则返回 1*/ if (fgets (tt, 13, fp) =NULL) return 1; memcpy(xxi, tt, i0); /把字符数组 tt中的 10个字符拷贝到数组 xxi中 xxi 10=0; /把 0赋给数组元素 xxi 10 fclose(fp); return 0; /*把结果 yy输出到文件 out.dat中*/ void WriteDat (void) FILE *fp; int i; fp=fopen(“out.dat“, “w“); for(i=0; i10; i+) fprintf(fp,
9、“%dn“, yyi); printf(“第%d 个人的选票数=%dn“, i+1, yyi); fclose(fp); (分数:100.00)_正确答案:()解析:int i,j; for(i=0;i100;i+) /对 100条记录逐条进行处理 /*如果数组元素 xxi的值不等于 1111111111时,即 xxi不为全选票时,计算 10个候选入的得票数*/ if(strcmp)(xxi, “1111111111“) for(j=0; j10; j+) if(xxij=“1“) yyj+; /如果 xxij等于“1“,说明第 j个得一票,所以 yyj加 1 解析 10 列 100行选票,全
10、选或不选的无效,统计存入数组。 根据题意,本程序涉及 10个候选人共 100条记录,其中,100 条记录的选票文件采用二维数组存储其数据,第一维表示 100条记录,第二维表示每条记录中 10个候选人的选中情况。可以通过两个 for循环对100条记录逐个比对,在第一层 for循环中,对 100条记录的每条记录情况进行扫描,在第二层 for循环语句中,判断数组元素 xxij的值是否等于字符 1,如果等于字符 1,说明第 j个人得了一票,则数组元素 yyj加 1。 先定义两个循环变量 i和 j。 指定第一个 for循环的循环条件,循环变量 i从 0开始,等于 100时结束,每循环一次,变量 i的值加1。 在 for循环中首先判断记录值不等于 1111111111的记录,然后计算 10个候选人的得票数,可以通过一个 for循环,对满足条件的记录中的每个数字再次比对,当数字等于 1时,将第 i个人的票数加 1。 注意,本程序中由于只有数值 1才会被计算到最后的结果中,因此,可以省去判断记录全为 0时记录无效的情况,因为,即使将 O参与到计算中,其计算结果也还是 0,不会影响到最终结果,只需判断记录为全1时无效即可。