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

admin2009-02-24  17

问题 读函数ReadDat()实现从文件ENG28.IN中读取一篇英文文章,存入到字符串数组xx中。请编制函数 encryptChar(),按给定的替代关系对数组xx中的所有字符进行替代,仍存入数组xx的对应的位置上,最后调用写函数WriteDat()把结果xx输出到文件PS28.DAT中。
   替代关系:f(p)=p*11 mod 256(p是数组xx中某一个字符的ASCII值,f(p)是计算后新字符的ASCII值),如果计算后f(p)的值小于等于32或f(p)对应的字符是小写字母,则该字符不变,否则将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("数据文件ENS28.IN不能打开! \n\007");
           return;
       }
       encryptChar ();
       WriteDat ();
   }

   int ReadDat (void)
   {
       FILE *fp;
       int i = 0;
       unsigned char *p;
       if((fp = fopen("ENG28.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("PS28.DAT",  "w");
       for (i = 0; i 〈 maxline; i++)
       {
          printf("%s\n", xx);
          fprintf(fp,  "%sin", xx);
       }
       fclose (fp);
   }

选项

答案void encrypt Char() { int i; char *pf; for (i=0; i〈maxline; i++) { pf=xx [i]; while (*pr !=0) { if ((*pf*11%256>=’a’ && *pf*11%256〈=’z’) || *Pf*11%256〈=32) { /*如果计算后的值小于等于32或对应的字符是小写字母*/ pf++; /*则不作任何操作,取下一个数进行处理*/ continue; } *p f=*pf*11%256; /*否则用新字符来替代这个字符*/ pf++; /*取下一个字符*/ } } }

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

最新回复(0)