欢迎您访问365答案网,请分享给你的朋友!
生活常识 学习资料

函数ReadDat()的功能是实现从文件IN35.DAT中读取一篇英文文章存入到字符串数组xx中请编制函数$o

时间:2018-02-09

函数ReadDat()的功能是实现从文件IN35.DAT中读取一篇英文文章存入到字符串数组xx中。请编制函数$ortCharD(),该函数的功能是:以行为单位对字符按从大到小的顺序进行排序,捧序后的结果仍按行重新存入字符串数组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())


{


printf ("数据文件 IN35.DAT 不能打开!\n\007 ");


return;


}


SortCharD();


WriteDat();


}


int ReadDat(void)


{


FILE *fp;


int i=0;


char *p;


if((fp=fopen("IN35.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;


clrscr();


fp=fopen("OUT35.DAT","w");


for(i=0;i<maxline;i++)


{


printf ("%s\n",xx[i]);


fprintf(fp,"%s\n',xx[i]);


}


fclose(fp);


}



答案说明:本题目答案来自网络整理或转载,最终答案请以官网为准。


答 案:void SortCharD() { int ijkstr1; char ch; for (i=O;imaxline;i++) { str1=strlen(xx[i]); /*求各行的长度*/ for(j=0;jstr1-1;j++) /*对字符按从大到小的顺序进行排序*/ for(k=j+1;kstr1;k++) if (xx[i][j]xx[i][k]) { ch=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=ch; } } }
void SortCharD() { int i,j,k,str1; char ch; for (i=O;imaxline;i++) { str1=strlen(xx[i]); /*求各行的长度*/ for(j=0;jstr1-1;j++) /*对字符按从大到小的顺序进行排序*/ for(k=j+1;kstr1;k++) if (xx[i][j]xx[i][k]) { ch=xx[i][j]; xx[i][j]=xx[i][k]; xx[i][k]=ch; } } } 解析:本题考查的知识点如下:
(1) 循环结构的嵌套。
(2) 字符的大小比较。
(3) 字符排序。
本题以行为单位对文章进行处理,首先要确定每一行中字符的个数。这个操作可使用字符串处理函数strlen(char*str)来完成。对字符从大到小排序依据的是字符的ASCII码,在C语言中,字符量可参与任何整型运算,所以可以直接使用比较运算符进行比较。排序使用前面介绍的“选择排序法”。最后使用循环结构对文章中的每一行都进行以上的操作。
相关推荐

Copyright © 2016-2020 www.365daan.com All Rights Reserved. 365答案网 版权所有 备案号:

部分内容来自互联网,版权归原作者所有,如有冒犯请联系我们,我们将在三个工作时内妥善处理。