1、三级网络技术机试-20 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.函数 readDat()的功能是从文件 in52.dat中读取 20行数据存放到字符串数组 xx中(每行字符串的长度均小于 80)。请编制函数 JsSod(),该函数的功能是:以行为单位对字符串变量的F 标为奇数位置上的字符按其 ASCII 值从小到大的顺序进行排序,排序后的结果仍按行重新存入字符串数组 xx中,最后调用函数 writeDat()把结果 xx输出到文件 out52.dat中。例如: 位置 0 1 2 3 4 5 6 7源字符串 h g f e d c b
2、 a则处理后字符串 h a f c d e b g。注意:部分源程序已给出。请勿改动主函数 main()、读函数 readDat()和写函数 writeDat()的内容。试题程序:#includestdio. h#includestring. h#includeconio. hchar xx20 80;void jsSortvoid main ()readDat ();jsSort ( );writeDat ();readDat ( )FILE *in;int i=0;char *p;in=fopen ( “in52. dat“, “r“ );while(i20 if(p) *p=0;i+;f
3、close (in);writeDat ()FILE *out;int i;out=fopen (“out52 .dat“, “w“);clrscr ( );for (i=0;i20;i+)printf (“%s/n“, xx i );fprint f (out, “%s/n“, xx i );fclose (out);(分数:100.00)_三级网络技术机试-20 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.函数 readDat()的功能是从文件 in52.dat中读取 20行数据存放到字符串数组 xx中(每行字符串的长度均小于 80)
4、。请编制函数 JsSod(),该函数的功能是:以行为单位对字符串变量的F 标为奇数位置上的字符按其 ASCII 值从小到大的顺序进行排序,排序后的结果仍按行重新存入字符串数组 xx中,最后调用函数 writeDat()把结果 xx输出到文件 out52.dat中。例如: 位置 0 1 2 3 4 5 6 7源字符串 h g f e d c b a则处理后字符串 h a f c d e b g。注意:部分源程序已给出。请勿改动主函数 main()、读函数 readDat()和写函数 writeDat()的内容。试题程序:#includestdio. h#includestring. h#incl
5、udeconio. hchar xx20 80;void jsSortvoid main ()readDat ();jsSort ( );writeDat ();readDat ( )FILE *in;int i=0;char *p;in=fopen ( “in52. dat“, “r“ );while(i20 if(p) *p=0;i+;fclose (in);writeDat ()FILE *out;int i;out=fopen (“out52 .dat“, “w“);clrscr ( );for (i=0;i20;i+)printf (“%s/n“, xx i );fprint f (
6、out, “%s/n“, xx i );fclose (out);(分数:100.00)_正确答案:(void jsSort () int i, j,k, strl;char ch;for (i=0; i20; i+) strl=strlen (xx i ); /*求各行字符串的长度*/for (j=l; j strl-2; j=j+2) /*将下标为奇数的字符按其 ASCII值从小到大的顺序进行排序*/for (k=j+2; kstrl; k=k+2)if(xxi jxxi k)ch=xxi j;xxi j=xxi k;xxi k =ch;)解析:解析本题考查的知识点如下:(1)二维数组的坊问及下标控制。(2)数据的排序。在本题中,将数据存放在一个二维数组 xx中。其中以行数为数组的第个下标,以字符串的最大长度 80为其第二个下标。因为以行为字符串处理的单位,首先要使用函数 strlen()求得每一行中字符的个数。只对字符串数组中下标为奇数的字符进行处理,可以从 xx01开始,若需要增加时都增加 2,则可实现只访问下标为奇数的数组元素。排序使用前面介绍的“选择排序法”。