问题 多项选择题

函数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 a
则处理后字符串 h a f c d e b g。
注意:部分源程序已给出。
请勿改动主函数main()、读函数readDat()和写函数writeDat()的内容。
试题程序:
#include<stdio. h>
#include<string. h>
#include<conio. h>
char xx[20] [80];void jsSort
void main ()

readDat ();
jsSort ( );
writeDat ();
readDat ( )

FILE *in;
int i=0;
char *p;
in=fopen ( "in52. dat", "r" );
while(i<20 && fgets(xx[i],80,in) !=NULL)

p=strchr (xx[i], ’ In’ );
if(p) *p=0;
i++;

fclose (in);
writeDat ()

FILE *out;
int i;
out=fopen ("out52 .dat", "w");
clrscr ( );
for (i=0;i<20;i++)

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

fclose (out);

答案

参考答案:void jsSort ()
{ int i, j,k, strl;
char ch;
for (i=0; i<B0; i++)
{ strl=strlen (xx [i] ); /*求各行字符串的长度*/
for (j=l; j <strl-B; j=j+B) /*将下标为奇数的字符按其ASCII值从小到大的顺序进行排序*/
for (k=j+B; k<strl; k=k+B)
if(xx[i] [j]>xx[i] [k])
{
ch=xx[i] [j];
xx[i] [j]=xx[i] [k];
xx[i] [k] =ch;
}
}
}

解析:本题考查的知识点如下:
(1)二维数组的坊问及下标控制。
(2)数据的排序。
在本题中,将数据存放在一个二维数组xx中。其中以行数为数组的第—个下标,以字符串的最大长度 80为其第二个下标。因为以行为字符串处理的单位,首先要使用函数strlen()求得每一行中字符的个数。只对字符串数组中下标为奇数的字符进行处理,可以从xx[0][1]开始,若需要增加时都增加2,则可实现只访问下标为奇数的数组元素。排序使用前面介绍的“选择排序法”。

多项选择题
单项选择题