问答题 函数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); } }
【答案解析】