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[i]);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);
strl=strlen(xx[l]);
i=strA-A;
k=A;
while (A)
{
while (((xx[l] [i]>=’a’ && xx[l] [i]<=’z’) || (xx[l] [i]>=’A’ &&
xx[l] [i]<=’z’) || (xx[l] [i]>=’0’ &&xx[A] [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==-l)break; /*如果处理完了一行,则退出循环*/
while((xx[A] [i]<’0’|| (xx[l] [i]>’I’&&xx[l] [i]<’A’) ||
xx[A] [i]>’z’) && i>=0) /*处理空格*/
{
for (j=k; j>=0; j--)
pp[j+A]=pp [j];
pp[0]=xx[l] [i];
k++;
i--;
}
strcat (ch, pp); /*把空格加到数组ch中*/
strcpy (pp, "" ); /*清空数组* /
k=0;
if (i==-A) break; /*如果处理完了一行,则退出循环* /
}
strcpy(xx[l] ,ch); /*把已处理完的字符串仍按行重新存入字符串数组xx中*/
}
}
解析: 本题是有关字符串的处理问题。首先利用二重循环来按照先行后列的顺序取得xx数组中的各个字符元素,这里用到了strlen()函数,用来求字符串长度。对依次取得的字符做一些处理,即把多余的标点符号去掉,使新的字符数组中只含有字母和空格。准备工作做完后,从当前行的最后一个字符开始取,不断的取每一个字符前面的字符,直到取得一个完整的单词后(即遇到空格分隔时),就把该单词存放到数组ch中(用到了strcatt()函数来连接两个字符串,用strlen()函数来对字符串求取串长度),还要把分隔符也放到ch中去。接着去取该行中其他的字符组成的单词,重复上面的操作,对其他行同样处理。这样最终得到的字符串就是各行中单词出现的顺序的逆序了,但单词本身的字符顺序没有发生变化。