函数ReadDat()的功能是实现从文件IN35.DAT中读取一篇英文文章存入到字符串数组xx中。请编制函数SortCharD(),该函数的功能是:以行为单位对字符按从大到小的顺序进行排序,排序后的结果仍按行重新存入字符串数组xx中,最后调用函数Write

admin2009-02-19  37

问题 函数ReadDat()的功能是实现从文件IN35.DAT中读取一篇英文文章存入到字符串数组xx中。请编制函数SortCharD(),该函数的功能是:以行为单位对字符按从大到小的顺序进行排序,排序后的结果仍按行重新存入字符串数组xx中,最后调用函数WriteDat()把结果xx输出到文件OUT35.DAT中。
   例如,原文:dAe,BfC
   CCbbAA
   结果:fedCBA,
   bbCCAA
   原始数据文件存放的格式是:每行的宽度均小于80个字符,含标点符号和空格。
   注意:部分源程序已给出。
   请勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。
   试题程序:
   #include<stdio.h>
   #include<string.h>
   #include<conio. h>
   char xx[50] [80];
   int maxline=0;
   int ReadDat (void);
   void WriteDat (void);
   void SortCharD ( )
   {
   void main ( )
   {
       clrscr ( );
       if (ReadDat())
       {
            print f ("数据文件 IN35.DAT 不能打开!\n\007");
            return;
       }
       SortCharD ( );
       WriteDat ( );
   }
   int ReadDat (void)
   {
       FILE *fp;
       int i=0;
       char *p;
       if ( (fD=fopen("IN35.DAT", "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 ()
       FILE *fp;
       int i;
       clrscr ( );
       fp=fopen ("OUT35.DAT", "w");
       for ( i=0; i<maxline; i++)
       {
             print f ("%s\n" ,xx );
             fprintf(fp,"%s\n",xx);
       }
       fclose (fp);
   }

选项

答案void SortCharD() { int i,j,k,str1; Char ch; for (i=0;i<maxline;i++) { str1=strlen(xx[i]); /*求各行的长度*/ for(j=0;j<str1-1;j++) /*对字符按从大到小的顺序进行排序*/ for(k=j+1;k<str1;k++) if (xx[i][j]<xx[i][k]) { ch=xx[i][j]; xx[i][i]=xx[i][k]; xx[i][k]=ch; } } }

解析 本题考查的知识点如下:
(1)循环结构的嵌套。
(2)字符的大小比较。
(3)字符排序。
本题以行为单位对文章进行处理,首先要确定每一行中字符的个数。这个操作可使用字符串处理函数strlen(char*s炷)来完成。对字符从大到小排序依据的是字符的ASCII码,在C语言中,字符量可参与任何整型运算,所以可以直接使用比较运算符进行比较。排序使用前面介绍的“选择排序法”。最后使用循环结构对文章中的每一行都进行以上的操作。
转载请注明原文地址:https://jikaoti.com/ti/bZC7FFFM
0

相关试题推荐
最新回复(0)