1、三级数据库技术机试-214 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.函数 ReadDat()的功能是实现从文件 IN7.DAT中读取一篇英文文章存入到字符串数组 xx中。请编制函数 SortCharD(),该函数的功能是:以行为单位对字符按从大到小的顺序进行排序,排序后的结果仍按行重新存入字符串数组 xx中,最后调用函数 WriteDat()把结果 XX输出到文件 OUT7.DAT中。例如,原文:dAe,BfCCCbbAA结果:fedCBA,bbCCAA原始数据文件存放的格式是:每行的宽度均小于 80个字符,含标点符号和空格。注意:
2、部分源程序已给出。请勿改动主函数 main()、读函数 ReadDat()和写函数 WriteDat()的内容。试题程序:#includestdio.h#includestring.h#includestdlib.hchar xx5080;int maxline=0;int ReadDat(void);void WriteDat(void);void SortCharD()void main()system(“CLS“);if(ReadDat()prinff(“数据文件 IN7.DAT不能打开!/n/007“);return;SortCharD();WriteDat();int ReadDat
3、(void)FILE *fp;int i=0;char *p;if(fp=fopen(“IN7.DAT“,“r“)=NULL)return 1;while(fgets(xxi,80,fp)!=NULL)P=strchr(xxi,/n);if(p) *p=0;i+;maxline=i;Mose(rp);retum 0;void WriteDat()FILE *fp;int i;system(“CLS“);fp=fopen(“OUT7.DAT“,“w“);for(i=0;imaxline;i+)prinff(“%s/n“,xxi);fprintf(fp,“%s/n“,xxi);fclose(fp)
4、;(分数:100.00)_三级数据库技术机试-214 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.函数 ReadDat()的功能是实现从文件 IN7.DAT中读取一篇英文文章存入到字符串数组 xx中。请编制函数 SortCharD(),该函数的功能是:以行为单位对字符按从大到小的顺序进行排序,排序后的结果仍按行重新存入字符串数组 xx中,最后调用函数 WriteDat()把结果 XX输出到文件 OUT7.DAT中。例如,原文:dAe,BfCCCbbAA结果:fedCBA,bbCCAA原始数据文件存放的格式是:每行的宽度均小于 80个字符,
5、含标点符号和空格。注意:部分源程序已给出。请勿改动主函数 main()、读函数 ReadDat()和写函数 WriteDat()的内容。试题程序:#includestdio.h#includestring.h#includestdlib.hchar xx5080;int maxline=0;int ReadDat(void);void WriteDat(void);void SortCharD()void main()system(“CLS“);if(ReadDat()prinff(“数据文件 IN7.DAT不能打开!/n/007“);return;SortCharD();WriteDat()
6、;int ReadDat(void)FILE *fp;int i=0;char *p;if(fp=fopen(“IN7.DAT“,“r“)=NULL)return 1;while(fgets(xxi,80,fp)!=NULL)P=strchr(xxi,/n);if(p) *p=0;i+;maxline=i;Mose(rp);retum 0;void WriteDat()FILE *fp;int i;system(“CLS“);fp=fopen(“OUT7.DAT“,“w“);for(i=0;imaxline;i+)prinff(“%s/n“,xxi);fprintf(fp,“%s/n“,xxi
7、);fclose(fp);(分数:100.00)_正确答案:(void SortCharD()int i,j,k; /*定义循环控制变量*/int str; /*存储字符串的长度*/char temp; /*定义数据交换时的暂存变量*/for(i=0;imaxline;i+) /*以行为单位获取字符*/str=strlen(xxi); /*求得当前行的字符串长度*/for(j=0;jstr-1;j+) /*对字符按从大到小的顺序进行排序*/for(k=j+1;kstr;k+)if(xxijxxik)temp=xxij;xxij=xxik;xxik=temp;)解析:解析 本题主要考查对数组的访问及排序问题。通过双重循环结构逐行获取字符并进行处理。首先使用字符串处理函数 stden()来求出每一行的字符串长度,然后运用选择法逐行对字符按照从大到小的顺序进行排序。