1.函數ReadDat( )的功能是實現從文件中讀取一篇英文文章存入到字符串數組xx中。請編制函數SortCharA( ),該函數的功能是:以行為單位對字符按從小到大的順序進行排序,排序後的結果仍按行重新存入字符串數組xx中。最後調用函數WriteDat( )把結果xx輸出到文件中。
例如,原文:dAe,BfC
CCbbAA
結果:ABCdef
AACCbb
原始數據文件存放的格式是:每行的寬度均小於80個字符,含標點符號和空格。
注意:部分源程序已給出。
請勿改動主函數main( )、讀函數ReadDat( )和寫函數WriteDat( )的內容。
試題程序:
#include
#include
#include
char xx[50][80];
int maxline=0;
int ReadDat(void);
void WriteDat(void);
void SortCharA()
{
}
void main()
{
system("CLS");
if (ReadDat())
{
printf("數據文件不能打開!n07");
return;
}
SortCharA();
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()
{
FILE *fp;
int i;
system("CLS");
fp=fopen("","w");
for(i=0;i
{
printf("%sn",xx[i]);
fprintf(fp,"%sn",xx[i]);
}
fclose(fp);
}
【答案】
void SortCharA()
{
int i,j,k; /*定義循環控制變量*/
int str; /*存儲字符串的長度*/
char temp; /*數據交換時的暫存變量*/
for (i=0;i
{
str=strlen(xx[i]); /*求得當前行的'字符串長度*/
for(j=0;j
for(k=j+1;k<>
if (xx[i][j]>xx[i][k])
{
temp=xx[i][j];
xx[i][j]=xx[i][k];
xx[i][k]=temp;
}
}
}
【解析】本題主要考查數組的訪問及排序問題。
通過雙重循環結構逐行獲取字符進行處理,首先使用字符串處理函數strlen()來求出每一行的字符串長度。然後運用選擇法逐行對字符按照從小到大的順序進行排序。
2.編寫一個函數findStr( ),該函數統計一個長度為2的字符串在另一個字符串中出現的次數。例如,假定輸入的字符串為"asd asasdfg asd as zx67 asd mklo",子字符串為"as",函數返回值是6。
函數ReadWrite( )的功能是實現從文件中讀取兩個字符串,並調用函數findStr(),最後把結果輸出到文件中。
注意:部分源程序已給出。
請勿改動主函數main() 和其他函數中的任何內容,僅在函數 findStr()的花括號中填入你所編寫的若干語句。
試題程序:
#include
#include
#include
void ReadWrite();
int findStr(char *str,char *substr)
{
}
void main()
{
char str[81],substr[3];
int n;
system("CLS");
printf("輸入原字符串:");
gets(str);
printf("輸入子字符串:");
gets(substr);
puts(str);
puts(substr);
n=findStr(str,substr);
printf("n=%dn",n);
ReadWrite();
}
void ReadWrite()
{
char ch,str[81],substr[3];
int n,len,i=0;
FILE *rf,*wf;
rf=fopen("","r");
wf=fopen("","w");
while(i<>
{
fgets(str,80,rf);
fgets(substr,10,rf);
len=strlen(substr)-1;
ch=substr[len];
if(ch=='n'||ch==0x1a)
substr[len]=0;
n=findStr(str,substr);
fprintf(wf,"%dn",n);
i++;
}
fclose(rf);
fclose(wf);
}【答案】
int findStr(char *str,char *substr)
{
int n=0; /*定義計數器變量,統計出現次數*/
char *p,*r; /*定義指針變量來分別指向兩個字符串*/
while(*str) /*如果字符串沒有結束,則一直循環下去*/
{
p=str; /*指針p指向字符串首地址*/
r=substr; /*指針r指向子字符串首地址*/
while(*r) /*若子字符串沒有結束,則循環繼續*/
if(*r==*p)
/*如果子字符串的第一個字符等於字符串中的該字符,則繼續比較下一個字符*/
{
r++;
p++;
}
else
break; /*否則退出循環*/
if(*r=='') /*如果子字符串在字符串中出現了一次*/
n++; /*則n加1,進行統計*/
str++; /*指向字符串中的下一個字符*/
}
return n; /*返回統計結果n*/
}
【解析】本題主要考查了指針的相關操作。
首先,通過外層的while循環取字符串的每一個字符,取完字符串的所有字符之後,循環才會終止。用兩個字符型指針分別指向兩個字符串。逐個將字符串的字符跟子字符串的字符對比,如果相等,則兩個指針都自加1,分別指向兩個串的下一個字符。若不相等,則主串的指針加1,子串的指針重新指向起始位置,繼續比較下一個字符。