对10个候选人进行选举,现有一个100条记录的选票文件IN84.DAT,其数据存放格式是每条记录的长度均为10位,第一位表示第一个人的选中情况,第二位表示第二个人的选中情况,依此类推。每一位候选人的记录内容均为字符0或1,1表示此人被选中,0表示此人未被选

admin2010-01-11  33

问题 对10个候选人进行选举,现有一个100条记录的选票文件IN84.DAT,其数据存放格式是每条记录的长度均为10位,第一位表示第一个人的选中情况,第二位表示第二个人的选中情况,依此类推。每一位候选人的记录内容均为字符0或1,1表示此人被选中,0表示此人未被选中,若一张选票选中人数大于5个人时被认为无效的选票。给定函数ReadDat()的功能是把选票数据读入到字符串数组xx中。请编制函数CoutRs()来统计每个人的选票数并把得票数依次存入yy[0]到yy[9]中,最后调用函数 WriteDat()把结果yy输出到文件OUT84.DAT中。
   注意:部分源程序已给出。
   请勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。
   试题程序:
    #inolude<stdio.h>
   char xx[100][11];
   int yy[10];
   int ReadDat(void);
   void WriteDat(void);
   void CoutRs(void)
   {
   }
   void main()
   {
      int i;
      for(i=0;i<10;i++)
         yy=0;
      if(ReadDat())
      {
         printf("数据文件IN84.DAT不能打开!\n\007");
         return;
      }
      CoutRs();
      WriteDat();
   }
   int ReadDat(void)
   {
      FILE *fp;
       int i;
      char tt[13];
      if((fp=fopen("IN84.DAT","r"))==NULL)   return 1;
      for(i=0;i<100;i++)
      {
         if(fgets(tt,13,fp)==NULL)  return 1;
         memcpy(xx,tt,10);
         xx[10]=0;
      }
      fclose(fp);
      return  0;
   }
   void WriteDat()
   {
      FILE *fp;
      int i;
      fp= fopen("OUT84.DAT","w");
      for(i=0;i<10;i++)
      {
          fprintf(fp,"%d\n",yy);
          printf("第%d个人的选票数=%d\n", i+1, yy);
      }
      fclose(fp);
}

选项

答案void CoutRs(void) { int i,count,j; char *pf; for(i=0;i<10;i++) yy[i]=0; for(i=0;i<100;i++) { pf=xx[i]; /*指针pf指向字符串的第一个字符*/ count=0; while(*pf) if(*pf== ’1’) { count++; /*统计每条记录中1的个数*/ pf++; } else pf++; if(count<=5) /*如果每条记录中1的个数小于等于5则为有效票*/ { pf=xx[i]; /*指针pf指向字符串的第一个字符*/ j=0; while(*pf) /*统计每个人的选票数并把得票数依次存入YY[0]到YY[9]中*/ if(*pf==’1’) { yy[j]+=1; j++; pf++; } else if(*pf==’0’) { j++; pf++; } } } }

解析 本题考查的知识点如下:
   (1) 二维数组的操作。
   (2) 指向数组的指针。
   在本题中,要先判断选票是否有效。因为记录存放在一个二维数组中,为了简便我们为数组的一组元素定义一个指向该数组每一行数据的指针,例如,char *p=xx[2]。初始时该指针指向该行的第一个元素,指针地址每加1,则指向下一个元素。这样就可以轻松地统计每一个选票。设一变量标记每一个选票中1的个数,若其不大于5,则选票有效。若选票有效,则依次查看哪一个元素为1,在数组”相应的元素上加10使用循环实现对所有记录的访问。
转载请注明原文地址:https://kaotiyun.com/show/Nb5Z777K
0

最新回复(0)