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

admin2009-02-19  24

问题 读函数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("数据文件 ENG28.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,  "%skn", xx);
       }
       fclose(fp);
   }

选项

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

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

最新回复(0)