函數ReadDat()的功能是實現從文件中讀取一篇英文文章存入到字符串數組xx中;請編制函數StrOL(),該函數的功能是:以行爲單位對行中以空格或標點符號爲分隔的所有單詞進行倒排。最後把已處理的字符串(應不含標點符號)仍按行重新存入字符串數組xx中,最後調用函數 WriteDat()把結果xx輸出到文件中。
例如,原文:You He Me
I am a student.
結果:Me He You
student a am I
原始數據文件存放的格式是:每行的寬度均小於80個字符,含標點符號和空格。
注意:部分源程序已給出。
請勿改動主函數main()、讀函數ReadDat()和寫函數WriteDat()的內容。
試題程序:
#include
#include
#include
#include
#include
char xx[50][80];
int maxline = 0;/* 文章的總行數 */
int ReadDat(void);
void WriteDat(void);
void StrOL(void)
{
}
void main()
{
system("CLS");
if (ReadDat ())
{
printf("數據文件 不能打開!n07");
return;
}
StrOL();
WriteDat();
}
int ReadDat(void)
{
FILE *fp;
int i = 0;
char *p;
if((fp = fopen("", "r")) == NULL) return 1;
while(fgets(xx[i], 80, fp) != NULL)
{
p = strchr(xx [i], 'n');
if(p) *p = 0;
i++;
}
maxline = i;
fclose(fp);
return 0;
}
void WriteDat(void)
{
FILE*fp;
int i;
system("CLS");
fp = fopen("", "w");
for(i = 0; i < maxline;="" i++)="">
{
printf("%sn", xx[i]);
fprintf(fp, "%sn", xx[i]);
}
fclose(fp);
}
【參考答案】
void StrOL(void)
{
int i,j,k; /*定義數組下標變量*/
char t[80],t1[80]; /*定義數組暫存取得的單詞*/
for(i=0;i
{
j=k=strlen(xx[i])-1; /*將每行末尾字符的下標保存在j和k中*/
t[0]=t1[0]=''; /*初始化兩個字符數組*/
while(1) /*無條件循環,循環體內有結束循環的.語句*/
{
while(isalpha(xx[i][j])==0&&j>=0)
/*若以j爲下標的字符不是字母並且還在數組xx之內*/
k=--j;
while(isalpha(xx[i][j])&&j>=0)
/*若以j爲下標的字符是字母並且還在數組xx之內*/
j--;
/*當退出這個循環時,xx[i][j+1]和xx[i][k]分別是同一個單詞的第一個和最後一個字母*/
memcpy(t1,&xx[i][j+1],k-j); /*將該單詞保存到字符數組t1*/
t1[k-j]=''; /*爲t1中的單詞添加字符串結束標誌*/
strcat(t,t1); /*將單詞保存到數組t中*/
strcat(t," "); /*單詞之間用空格分隔*/
if(j<0)>
break; /*則退出外層while循環*/
}
strcpy(xx[i],t); /*按行將處理完了字符串重新保存到數組xx中*/
}
}
【解析】
本題的主要算法是先讓兩字符指針都指向每一行字符的串尾,然後使其中一指針(p1)往前移動,當出現pl指向的不是字母時則表示在p1+1與 p2之間是一個單詞,將該單詞存入字符數組t1中,最後將t1連接到新串t中;接着再往前找第二個單詞,依次類推直到p1越過字符串的起始位置。再將處理完的字符串重新儲存到數組xx中,然後進入下一行的處理過程。