问答题
函数ReadDat()实现从IN.DAT文件中读取一篇英文文章并存入到字符串数组xx中。请编写函数StrOL(),其函数的功能是:以行为单位对行中以空格或标点符号为分隔的所有单词进行倒排。最后把已处理的字符串(应不含标点符号)仍按行重新存入字符串数组xx中,最后调用函数WriteDat(),把结果xx输出到OUT.DAT文件中。
例如: 原文:You He Me
I am a student.
结果:Me He You
student a am I
原始数据文件存放的格式是:每行的宽度均小于80个字符,含标点符号和空格。
注意:部分程序已经给出。
请勿改动主函数main()、读数据函数ReadDat0和输出数据函数WriteDat()的内容。
#include <stdio.h>
#include <string.h>
#include <conio.h>
#include <ctype.h>
char xx [50][80];
int maxline=0; /*文章的总行数*/
int ReadDat(void);
void WriteDat(void);
void StrOL(void)
{
}
void main()
{
if(ReadDat())
{
printf("数据文件IN.DAT不能打开!/n/007");
return;
}
StrOL();
WriteDat();
}
int ReadDat(void)
{
FILE *fp;
int i=0;
char *p;
if((fp=fopen("IN.DAT","r"))==NULL)
return,1;
while(fgets(xx[i],80,fp)!=NULL)
{
p=strchr(xx[i],'/n');
if (p)
i++;
}
maxline=i;
fclose(fp);
return 0;
}
void WriteDat(void)
{
FILE *fp;
int i;
fp=fopen("OUT.DAT","w");
for(i=0;i<maxline;i++)
{
printf("%s/n",xx[i]);
fprintf(fp,"%s/n",xx[i]);
}
fclose(fp);
}
【正确答案】void StrOL(void)
{
int i,j,k,strl,1;
/*循环遍历英文文章的全部字符,将既不是字母也不是空格的字符替换成空格*/
for (i=0;i<maxline;i++)
for (j=0;j<(int)strlen(xx[i]);j++)
if (!isalpha(xx[i][j]) && xx[i][j]!=' ')
xx[i][j]=' ';
for (1=0;1<maxline;1++) /*循环以遍历文章的每一行*/
{
char ch[80]={0};
char pp[80]={0};
strl=strlen(xx[1]);
i=strl-1; /*求出当前行最后一个字符的位置*/
k=0;
while(1)
{
/*从最后一个字符往前循环遍历当前行,直到碰到非字母字符或到行首*/
/*(即以从后往前的顺序查找单词)*/
while(isalpha(xx[1][i]) && i>=0)
{
/*将字符数组pp中的前k+1个字符往后移动一位*/
for (j=k;j>=0;j--)
pp[j+1]=pp[j];
pp[0]=xx[1][i]; /*将当前字符存入到pp的第1个位置*/
k++; /*pp中的有效字符数增1*/
i--; /*继续遍历前一个字符*/
}
strcat(ch,pp); /*将pp中的单词连接到字符数组ch的末尾*/
strcpy(pp," "); /*清空pp数组*/
k=0;
if(i<0)
break; /*若已遍历到行首则跳出该循环*/
/*从后往前循环遍历当前行,直到碰到字母字符或到行首*/
/*(即以从后往前的顺序查找两个单词之间的字符)*/
while(!isalpha(xx[1][i]) && i>=0)
{
/*将字符数组pp中的前k+1个字符往后移动一位*/
for (j=k;j>=0;j--)
pp[j+1]=pp[j];
pp[0]=xx[1][i]; /*将当前字符存入到pp的第1个位置*/
k++; /*pp中的有效字符数增1*/
i--; /*继续遍历前一个字符*/
}
strcat(ch,pp); /*将pp中的字符串连接到ch的末尾*/
strcpy(pp," "); /*清空pp数组*/
k=0;
if(i<0)
break; /*若已遍历到行首则跳出该循环*/
}
/*执行到这里,当前行已遍历完毕,用操作结果覆盖掉原来内容*/
strcpy(xx[1],ch);
}
}
【答案解析】