| 函数ReadDat()实现从文件IN.DAT中读取20行数据存入到字符串数组xx中(每行字符串长度均小于80字符);请编制jsSort(),其函数的功能是;以行为单位对字符串按给定的条件排序,排序后的结果仍按行重新存入字符串数组xx中。最后main()函数调用WriteDat()把结果xx输出到文件OUT.DAT中。 条件:从字符串中间一分为二,左边部分按字符的ASCII值降序排列,右边部分按字符的ASCII值升序排列。如果原字符串长度为奇数,则最中间字符不参加排序,字符仍放在原位置上。
 
 位置   0 1 2 3 4 5 6 7 8
 字串   a b c d h g f e
 1 2 3 4 9 8 7 6 5
 处理后 d c b a f e g h
 4 3 2 1 9 5 6 7 8
 
 程序:
 #include
 #include
 #include
 
 char xx[20][80];
 
 int ReadDat(void);
 void WriteDat(void);
 
 void jsSort(void)
 {
 int i,j,k,strl,half;
 char ch;
 for (i=0;i<20;i++)
 {
 strl=strlen(xx[i]);
 half=strl/2;
 
 for (j=0;j    for (k=j+1;k      if (xx[i][j]      {ch=xx[i][j]; xx[i][j]=xx[i][k];  xx[i][k]=ch;}
 
 if (strl%2) half++;
 
 for (j=half;j    for (k=j+1;k      if (xx[i][j]>xx[i][k])
 {ch=xx[i][j]; xx[i][j]=xx[i][k];  xx[i][k]=ch;}
 }
 }
 
 void main()
 {
 ReadDat();
 jsSort()
 WriteDat();
 system("pause");
 }
 
 int ReadDat()
 {
 FILE *in;
 int i=0;
 char *p;
 
 in=fopen("IN.DAT","r");
 while (i<20 && fgets(xx[i],80,in)!=NULL)
 {
 p=strchr(xx[i],’\n’);
 if (p)  *p=0;
 i++;
 }
 fclose(p);
 return 0;
 }
 
 void WriteDat(void)
 {
 FILE *out;
 int i;
 
 out=fopen("OUT.DAT","w");
 for (i=0;i<=20;i++)
 {
 printf("%s\n",xx[i]);
 fprintf(out,"%s\n",xx[i]);
 }
 fclose(out);
 return 0;
 }
 |