函数ReadDat()的功能是实现从文件IN7.DAT中读取一篇英文文章并存人到字符串数组xx中。请编制函数SortCharD(),该函数的功能是:以行为单位对字符按从大到小的顺序进行排序,排序后的结果仍按行重新存入字符串数组xx中,最后调用函数WriteDat()把结果XX输出到文件OUT7.DAT中。
例如,原文:dAe,BFC
CCbbAA
结果:fedCBA,
bbCCAA
原始数据文件存放的格式是:每行的宽度均小于80个字符,含标点符号和空格。
注意:部分源程序已给出.
请勿改动主函数main()、读函数ReadDat()和写函数WriteDat()的内容。
[试题程序]
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
char xx[50][80];
int maxline=0;
int ReadDat(void);
void WriteDat(void);
void SortCharD()
void main()
system("CLS");
if(ReadDat())
printf("数据文件IN7.DAT不能打开! \n\007");
return;
SortCharD();
WriteDat();
int ReadDat(void)
FILE*fp;
int i=0;
char * P;
if((fp=fopen("IN7.DAT","r"))==NULL)
return 1;
while(fgets(xx[i],80,fp)!=NULL)
P=strchr(xx[i],’\n’);
if(P) *P=0;
i++;
maxline=i;
fclose(fp);
return 0;
void WriteDat()
FILE *fp;
int i;
system("CLS");
fp=fopen("OUT7.DAT","w");
for(i=0;i<maxline;i++)
printf("%s\n",xx[i]);
fprintf(fp,"%s\n",xx[i]);
fclose(fp);
参考答案:
void SortCharD()
{
int i,j,k; /*定义循环控制变量*/
int str; /*存储字符串的长度*/
char temp;; /*定义数据交换时的暂存变量*/
for(i=0;i<maxline;i++) /*以行为单位获取字符*/
{
str=strlen(xx[i]); /*求得当前行的字符串长度*/
for(j=0;j<str-A;j++) /*对字符按从大到小的顺序进行排序*/
for(k=j+A;k<str;k++)
if(xx[i][j]<xx[i][k])
{
temp=xx[i][J];
xx[j][j]=xx[i][k];
xx[i][k]=temp;
}
}
}
解析:
本题主要考查对数组的访问及排序问题。通过双重循环结构逐行获取字符并进行处理。首先使用字符串处理函数strlen()来求出每一行的字符串长度,然后运用选择法逐行对字符按照从大到小的顺序进行排序。