第 1 頁:題目1 |
第 2 頁:題目2 |
第 3 頁:題目3 |
第 4 頁:題目4 |
第 5 頁:題目5 |
**題目4
函數ReadDat()實現從文件IN.DAT中讀取一篇英文文章存入到字符串數組xx中,請編制函數StrOL(),其函數的功能是:以行為單位對行中以空格或標點符號為分隔的所有單詞進行倒排。最后把已處理的字符串(應不含標點符號)仍按行重新存入字符串數組xx中,最后調用函數writeDat()把結果xx輸出到文件OUT6.DAT中。
例如:原文:You He Me
I am a student.
結果:Me He You
student a am I
原始數據文件存放的格式是:每行的寬度均小于80個字符,含標點符號和空格。
部分源程序存在文件prog1.c中。
請勿改動主函數main()、讀數據函數ReadDat()和輸出數據函數writeDat()的內容。
#include
#include
#include
#include
char xx[50][80];
int maxline=0;/*文章的總行數*/
int ReadDat(void);
void WriteDat(void);
/*在無憂及捷成版模擬系統中都通過測試(輸入文件句末有標點的在輸出文件中句前有空格*/
void StrOL(void)
{ int i,j,k,s,m,strl;
char str[80];
for(i=0;i { strl=strlen(xx[i]); memset(str,0,80); /*初始化這字符串數組str*/ s=k=0; for(j=strl-1;j>=0;j--) /*從當前字符串尾部開始向前倒序循環(huán),實現題意要求的倒排*/ { if(isalpha(xx[i][j])) k++; /*如果當前字符是字母a~z或A~Z,則k加一*/ else { for(m=1;m<=k;m++) /*否則將長度為k的單詞順序存入到字符串數組str中,s值加1*/ str[s++]=xx[i][j+m]; k=0; /*將k值清0,以方便下一個單詞的長度計數*/ } if(!isalpha(xx[i][j])) str[s++]=' '; /*如果當前字符不是字母a~z或A~Z,則以空格代之存入到字符串數組str中,s值加一*/ } for(m=1;m<=k;m++) /*此時的k值為當前字符串中第一個單詞的長度,但在上一個for循環(huán)中沒能存入到字符串數組str中,所以在這里將其存入到str中*/ str[s++]=xx[i][j+m]; str[s]='\0'; /*在當前行尾加0以標記此行的結束*/ strcpy(xx[i],str); /*將倒排好的當前字符串重新存回到當前行xx中*/ } } void main() { clrscr(); 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)*p=0; i++; } maxline=i; fclose(fp); return 0; } void WriteDat(void) { FILE *fp; int i; clrscr(); fp=fopen(“OUT6.DAT”,“w”); for(i=0;i printf(“%s\n”,xx[i]); fprintf(fp,“%s\n”,xx[i]); } fclose(fp); } 捷成版模擬系統中的解法 /*在無憂模擬系統中沒通過測試(輸入文件句末有標點的在輸出文件中句前無空格*/ void StrOL(void) { int i, j ; char word[21], yy[80], zz[80], *p ; for(i = 0 ; i < maxline ; i++) { p = xx[i] ; j = 0 ; memset(word, 0, 21) ; memset(yy, 0, 80) ; while(*p) { if(isalpha(*p)) { word[j++] = *p++ ; if(*p) continue ; } strcpy(zz, yy) ; sprintf(yy, “%s %s”, word, zz) ; j = 0 ; memset(word, 0, 21) ; while(*p && (!isalpha(*p))) p++ ; } strcpy(xx[i], yy) ; } } 另一解法(): /*在無憂及捷成版模擬系統中都通過測試(輸入文件句末有標點的在輸出文件中句前有空格*/ void StrOL(void) { int i,j,m; char str[80]; for(i=0;i { m=strlen(xx[i]); memset(str,0,80); for(j=m-1;j>=0;j--) if(!isalpha(xx[i][j])) { strcat(str,xx[i]+j+1); strcat(str,“ ”); xx[i][j]='\0'; } strcat(str,xx[i]); strcpy(xx[i],str); } } 實際上機考試時上面幾種解法都可以采用。
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內蒙古 |