函数ReadDat()的功能是实现从文件ENG9.IN中读取一篇英文文章,存入到字符串数组xx中。请编制函数encryptChat(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数WriteDat()把结果xx

admin2009-02-15  22

问题 函数ReadDat()的功能是实现从文件ENG9.IN中读取一篇英文文章,存入到字符串数组xx中。请编制函数encryptChat(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用函数WriteDat()把结果xx输出到文件PS9.DAT中。
   替代关系:f(p)=p* 11 mod 256(p是数组xx中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),如果原字符的ASCII值是偶数或计算后f(p)的值小于等于32,则该字符不变,否则将f(p)所对应的字符进行替代。
   注意:部分源程序已给出,原始数据文件存放的格式是:每行的宽度均小于80千字符。
   请勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。
试题程序:
     #include <stdio.h>
     #include <string.h>
     #include <conio.h>
     #include <ctype.h>
     unsigned char xx[50] [80];
     int maxline = 0; /*文章的总行数 */
     int ReadDat(void);
     void WriteDat(void);
     void encryptChar()
     {
     }
     main ( )
     {
         clrscr();
         if (ReadDat ( ) )
         {
            printf ("数据文件ENG9.IN不能打开! \n\007 ");
            return;
         }
         encryptChar();
         WriteDat();
    }
    int ReadDat(void)
     FILE *fp;
     int i= 0;
     unsigned char *p;
     if  ((fp = fopen("ENG9.IN","r"))  ==NULL)  return 1;
     while(fgets(xx, 80, fp)  !=NULL)
    {
          p = strchr(xx, ’\n’);
          if(p) *p = 0;
          i++;
    }
    maxline = i;
    fclose(fp);
    return 0;
   }
   void WriteDat(void)
   {
      FILE *fp;
      int i;
      fp = fopen("PSg.DAT",  "w"  ;
      for(i = 0; i < maxline; i++)
      {
          printf("%s\n", xx);
          fprintf(fp,  "%s\n", xx);  }
          fclose(fp);
     }

选项

答案void encryptChar ( { int i; char *pf; for (i=0; i<maxline; i++) { pf=xx [i]; /* 指针pf指向当前行的首地址*/ while (*pf ! =0) { if(*pf%2==0 || *pf*11%256<=32) ; /*如果原字符的ASCII值是偶数或计算后的值小于等 于32,则该字符不变* / else *pf=*pf*11%256; /* 否则将所对应的字符进行替代*/ pf++; /*指针pf指向下一个字符*/ } } }

解析 本题主要考查用指针变量来控制字符数组,由于要对已有二维字符数组的所有元素逐个处理,因此,需要定义一个字符指针变量来控制原二维数组的各行。当前行如果确定下来,用指针的移动就可以依次扫描该行的所有字符元素,每得到一个字符就对它进行条件判断。根据题意,条件用“if(*pf%%2==0 || *pf*11% 256<=32)”来实现,如果该字符不满足上述条件,就用一个新的字符来替代,新的字符是当前字符乘以11的结果再去与256求余数,处理完毕后,指针去取下一个字符。如果该字符满足所给条件,将不做任何操作,指针直接下移,去取下一个字符,对下一个字符进行处理。
转载请注明原文地址:https://kaotiyun.com/show/P3fZ777K
0

最新回复(0)