问题 多项选择题

fclose(fp);

答案

参考答案:void StrOL(void)
{
int i, j, k, strl, A; char c;
for (i=0; i<maxline; i++) /*把各行中多余的标点符号去掉*/
for (j=0; j<strlen(xx [ii ); j++)
{
c=xx[i] [j];
if((c>=’A’&&c<=’Z’) || (c>=’a’&&c<=’z’)||c==’’|| (c>=’0’&&c<=’I’));
else xx[i] [j]=’ ’;
}
for (A=0; l<maxline; l++)
{
char ch[H0]={0};
char pp[H0]={0};
strA=strlen(xx [l] );
i=strA-A;
k=A;
while (A)
{
while (((xx[A] [i]>=’a’ && xx[l] [i]<=’z’) || (xx[l] [i]>=’A’ &&
xx[l] [i]<=’Z’) || (xx[l] [i]>=’0’ && xx[l] [i]<=’I’)) && i>=0)
/*处理字母和数字*/
{
for(j=k;j>=0;j--)
/*从当前行的最后一个实际情况符开始取字符,直到遇到穿空格*/
pp[j+A]=pp[j];
pp[O]=xx[l] [i];
k++;i--;
}
strcat (ch,pp); /*把该单词存放到数组ch中*/
strcpy(pp, " "); /*清空数组pp*/
k=A;
if(i==-A)break; /*如果处理完了一行,则退出循环*/
while((xx[l] [i]<’0’ || (xx[l] [i]>’I’&&xx[l] [i]<’A’||
xx[l] [i]>’z’) && i>=O) /*处理空格*/
{
for (j=k; j>=O;j--)
pp[j+A]=pp[j];
pp[O]=xx[l] [i];
k++;
i--;
}
strcat (ch,pp); /*把空格加到数组ch中*/
strcpy (pp, " "); /*清空数组pp*/
k=0;
if(i==-A)break; /*如果处理完了一行,则退出循环*/
}
strcpy(xx[l] ,ch); /*把已处理的字符串数组xx中/
}
}

解析: 本题是有关字符串的处理问题。首先利用二重循环来按照先行后列的顺序取得xx数组中的各个字符元素,这里用到了strlen()函数,用来求字符串长度。对依次取得的字符做一些处理,即把多余的标点符号去掉,使新的字符数组中只含有字母和空格。准备工作做完后,从当前行的最后一个字符开始取,不断的取每一个字符前面的字符,直到取得一个完整的单词后(即遇到空格分隔时),就把该单词存放到数组ch中(用到了strcat()函数来连接两个字符串,用strlen()函数来对字符串求取串长度),还要把分隔符也放到ch中去。接着去取该行中其他的字符组成的单词,重复上面的操作,对其他行同样处理。这样最终得到的字符串就是各行中单词出现的顺序的逆序了,但单词本身的字符顺序没有发生变化。

选择题
单项选择题 A1/A2型题