问答题 对10个候选人进行选举,现有一个存有100条记录的选票数据文件IN.DAT,其数据存放的格式是每条记录的长度均为10位,第一位表示第一个人的选中情况,第二位表示第二个人的选中情况,依此类推。每一位内容均为字符0或1,1表示此人被选中,0表示此人未被选中,若一张选票中选中人数小于等于5个人时,则被认为是无效的选票。给定函数ReadDat()的功能是把选票数据读入到字符串数组xx中。请编写函数CountRs()来统计每个人的选票数,并把得票数依次存入yy[0]~yy[9]中,最后调用函数WriteDat(),把结果yy输出到文件OUT.DAT中。
请勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。
[试题程序]
#include<stdio.h>
#include<memory.h>
char xx[100][11];
int yy[10];
int ReadDat(void);
void WriteDat(void);
void CountRs(void)
{
}
void main()
{
int i;
for(i=0; i<10; i++)
yy[i]=0;
if(ReadDat())
{
printf("选票数据文件IN.DAT无法打开!\007\n");
return;
}
CountRs();
WriteDat();
}
int ReadDat(void)
{
FILE*fp;
int i;
char tt[13];
if((fp=fopen("IN.DAT", "r"))==NULL)
return 1;
for(i=0; i<100; i++)
{
if(fgets(tt, 13, fp)==NULL)
return 1;
memcpy(xx[i], tt, 10);
}
fclose(fp);
return 0;
}
void WriteDat(void)
{
FILE*fp;
int i;
fp=fopen("OUT.DAT", "w");
for(i=0; i<10; i++)
{
fprintf(fp, "%d\n", yy[i]);
printf("第%d个人的选票数=%d\n", i+1, yy[i]);
}
fclose(fp);
}
【正确答案】
【答案解析】void CountRs(void)
{
int i, j; /*定义循环控制变量*/
int cnt; /*用来存储每张选票中选中人数,以判断选票是否有效*/
for(i=0; i<10; i++) /*初始化数组yy*/
yy[i]=0;
for(i=0; i<100; i++) /*依次取每张选票进行统计*/
{
cnt=0; /*初始化计数器变量*/
for(j=0; j<10; j++) /*统计每张选票的选中人数cnt*/
if(xx[i][j]=="1")
cnt++;
if(cnt>5) /*当cnt值大于5时为有效选票*/
{
for(j=0; j<10; j++) /*统计有效选票*/
if(xx[i][j]=="1")
yy[j]++;
}
}
} [考点] 本题考查选票的统计。考查的知识点主要包括:C语言循环结构,if条件判断结构和逻辑表达式,二维数组操作。
首先通读题目,得知此题属于选票的统计题型;其次分析题干要求,本题要求实现CountRs(void)函数的功能,该函数需要统计出100条选票数据,并将统计结果保存入数组yy中;接着归纳出本题有2个关键点:关键点1如何统计每张选票的选择情况;关键点2根据题目给出的条件“一张选票选中人数小于等于5个人时则被认为无效”判断选票是否有效。首先,对数组yy元素初始化为0;接着通过一个循环嵌套结构依次判断每张选票数据的十个选举标志,同时每张选票的投票数量,对于不满足条件的选票数据直接跳过,并统计有效选票的投票情况到数组 yy中。