★☆題目9(無憂id 28;id 124;上機題庫id 16 字元串排序題)
函式readdat()實現從檔案in.dat中讀取一篇英文文章存入到字元串數組xx中,請編制函式sortchard(),其函式的功能是:以行為單位對字元按從大到小的順序進行排序,排序後的結果仍按行重新存入字元串數組xx中,最後調用函式writedat()把結果xx輸出到檔案out2.dat中。
例:原文:dae,bfc.
ccbbaa
結果:fedcba.
bbccaa
原始數據檔案存放的格式是:每行的寬度均小於80個字元,含標點符號和空格。
部分源程式存在檔案prog1.c中。
請勿改動主函式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)
{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;}
}
}
void main()
{
clrscr();
if(readdat()){
printf("數據檔案in.dat不能打開!\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);
}