函数ReadDat()的功能是实现从文件IN39.DAT中读取一篇英文文章存入到字符串数组xx中。请编制函数ChA㈠,该函数的功能是:以行为单位把字符串的第一个字符的ASCII值加第二个字符的ASCII值,得到第一个新的字符,第二个字符的ASCII值加第三

admin2009-02-19  29

问题 函数ReadDat()的功能是实现从文件IN39.DAT中读取一篇英文文章存入到字符串数组xx中。请编制函数ChA㈠,该函数的功能是:以行为单位把字符串的第一个字符的ASCII值加第二个字符的ASCII值,得到第一个新的字符,第二个字符的ASCII值加第三个字符的ASCII值,得到第二个新的字符,以此类推一直处理到倒数第二个字符,最后一个字符的ASCII值加第一个字符的ASCII值,得到最后一个新的字符,得到的新字符分别存放在原字符串对应的位置上。最后把已处理的字符串逆转后仍按行重新存入字符串数组肛中,并调用函数WriteDat()把结果xx输出到文件OUT39.DAT中。
   注意:部分源程序已给出。
   原始文件存放的格式是:每行的宽度小于80个字符,含标点符号和空格。
   请勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。
   试题程序:
   #include<stdio.h>
   #include<string.h>
   #incIude<conio.h>
   char xx[50] [80];
   int maxline=0;
   int ReadDat();
   void writeDat();
   void ChA(void)
   {
   void main ()
   {
     clrscr ( );
     if (ReadDat ( ) )
     {
           printf ("数据文件IN39 .DAT 不能打开!\n\007");
           return;
     }
     ChA{ );
     WriteDat ( );
   }
   int ReadDat (void)
   {
     FILE *fp;
     int i=0;
     char *p;
     if ( (fp= fopen ( "IN39. DAT", "r" ) ) ==NULL )
           return 1;
     while (fgets (xx , 80, fp)! =NULL)
     {
           p=strchr(xx, ’In’);
           if(p)  *p=0;
           i++;
     }
     maxline=i;
     fclose (fp);
     return 0;
   }
   void WriteDat ( )
   {
      FILE *fp;
      int i;
      clrscr ( );
      fp=fopen ("OUT39.DAT", "w");
      for (i=0; i<maxline; i++)
            printf ( "%s\n" ,xx );
            fprintf(fp,"%s\n",xx);
      }
      fclose (fp);
   }

选项

答案void ChA(void) { int i,j, k,str; char ch; for(i=0;i<maxline;i++) { str=strlen (xx[i]); /*求各行字符串的总长度*/ ch=xx[i][0]; for(j=0;j<str-1;j++) /*将该字符的ASCII值与下一个字符的ASCII值相加,得到新的字符*/ xx[i][j]+=xx[i][j+1]; xx[i][str-1]+=ch; /*将最后一个字符的ASCII值与第一个字符的ASCII值相加,得到最后一个新的字符*/ for(j=0,k=str-1; j<str/2;j++,k--) /*将字符串逆转后仍按行重新存入字符串数组xx中*/ { ch=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=ch; } } }

解析 本题考查的知识点如下:
(1)字符变量的整数运算。
(2)字符的逆序排列。
因为是以行为处理单位,所以要先求得每一行中字符的个数。在C语言中,字符型数据可参与任何整数运算,实际参与运算的是字符的ASCII码。这里可以直接将字符的ASCII码相加,即可得到所要结果。使用循环结构依次对字符进行处理,最后一个字符要单独处理。逆序排列采用的方法是:从两边向中间移动。数组中第一个字符与最后,个字符交换,第二个与倒数第二个交换,按照此规律直到中间一个或两个字符(数组中字符个数为奇数时,最后中间只有一个字符,否则有两个字符)。
转载请注明原文地址:https://jikaoti.com/ti/zRQ7FFFM
0

最新回复(0)