1、三级信息管理技术机试-259 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.函数 readDat()的功能是从文件 in74.dat 中读取 20 行数据存放到字符串数组 xx 中(每行字符串的长度均小于 80)。请编制函数 jsSort(),该函数的功能是:以行为单位对字符串变量的下标为奇数位置上的字符按其 ASCII 值从小到大的顺序进行排序,排序后的结果仍按行重新存入字符串数组 xx 中,最后调用函数 writeDat()把结果 xx 输出到文件 out74.dat 中。注意:部分源程序已给出。请勿改动主函数 main()、读函数
2、readDat()和写函数 writeDat()的内容。试题程序:#include stdio.h#include string.h#include stdlib.hchar xx2080;void readDat();void writeDat();void jsSort()void main()readDat();jsSort();writeDat();void readDat()FILE * in;int i=0;char * p;in=fopen(“in74.dat“,“r“);while(i20 & fgets(xxi,80,in)!=NULL)p=strchr(xxi,/n);if
3、(p)*p=0;i + +;fclose(in);void writeDat()FILE * out;int i;out=fopen(“out74.dat“,“w“);system(“CLS“);for(i=0;i20;i + +)printf(“% s/n“,xxi);fprintf(out,“% s/n“,xxi);fclose(out);(分数:100.00)_三级信息管理技术机试-259 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.函数 readDat()的功能是从文件 in74.dat 中读取 20 行数据存放到字符串数组 xx
4、 中(每行字符串的长度均小于 80)。请编制函数 jsSort(),该函数的功能是:以行为单位对字符串变量的下标为奇数位置上的字符按其 ASCII 值从小到大的顺序进行排序,排序后的结果仍按行重新存入字符串数组 xx 中,最后调用函数 writeDat()把结果 xx 输出到文件 out74.dat 中。注意:部分源程序已给出。请勿改动主函数 main()、读函数 readDat()和写函数 writeDat()的内容。试题程序:#include stdio.h#include string.h#include stdlib.hchar xx2080;void readDat();void w
5、riteDat();void jsSort()void main()readDat();jsSort();writeDat();void readDat()FILE * in;int i=0;char * p;in=fopen(“in74.dat“,“r“);while(i20 & fgets(xxi,80,in)!=NULL)p=strchr(xxi,/n);if(p)*p=0;i + +;fclose(in);void writeDat()FILE * out;int i;out=fopen(“out74.dat“,“w“);system(“CLS“);for(i=0;i20;i + +)
6、printf(“% s/n“,xxi);fprintf(out,“% s/n“,xxi);fclose(out);(分数:100.00)_正确答案:(void jsSort()int i,j,k; /*定义循环控制变量*/int str; /*定义存储字符串长度的变量*/char temp; /*定义数据交换时的暂存变量*/for(i=0;i20;i + +) /*逐行对数据进行处理*/str=strlen(xxi); /*求各行字符串的长度*/for(j=1;jstr-2;j=j+2) /*将下标为奇数的字符按其 ASCII 值从小到大的顺序进行排序*/for(k=j+2;kstr;k=k+2)if(xxijxxik)temp=xxij;xxij=xxik;xxik=temp;)解析:解析 本题主要考查的是二维数组的访问及数据的排序问题。在本题中,将数据存放在一个二维数组 xx 中。其中以行数为数组的第一个下标,以字符串的最大长度 80为其第二个下标。因为以行为字符串处理的单位,首先要使用函数 strlen()求得每一行中字符的个数。只对字符串数组中下标为奇数的字符进行处理,可以从 xx01开始,若需要增加时都增加 2,则可实现只访问下标为奇数的数组元素。排序使用前面介绍的“选择排序法”。