29题 函数ReadDat()实现从文件IN.DAT中读取一篇英文文章存入到字符串数组xx中,请编制函数SortCharD(),其函数的功能是:以行为单位对字符按从大到小的顺序进行排序,排序后的结果仍按行重新存入字符串数组xx中,最后调用函数writeDat()把结果xx输出到文件OUT2.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)
{

}

void main()
{
clrscr();
if(ReadDat()){
printf(" 数据文件ENG.IN不能打开!\n\007" );
return;
}
SortCharD();
WriteDat();
}

int ReadDat(void)
{
FILE *fp;
int i=0;
char *p;

if((fp=fopen(" IN.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(void)
{
FILE *fp;
int i;

fp=fopen(" OUT2.DAT" ," w");
for(i=0;i<maxline;i++){
printf(" %s\n" ,xx[i]);
fprintf(fp," %s\n" ,xx[i]);
}
fclose(fp);
}


注:该题采用的是起(冒)泡法进行排序。
void sortchard(void)
{
int i,j,k,strl;
char ch;
for(i=0;i<maxline;i++)
{strl=strlen(xx[i]);
for(j=0;j<strl-1;j++)
for(k=j+1;k<strl;k++)
if(xx[i][j]<xx[i][k])
{ch=xx[i][j];
xx[i][j]=xx[i][k];
xx[i][k]=ch;
}
}
}

 

返回南开百题目录

www.163164.cn 联系QQ:3149886