1、三级信息管理技术机试-264 及答案解析(总分:100.00,做题时间:90 分钟)1.编写一个函数 findStr(),该函数统计一个长度为 2 的字符串在另一个字符串中出现的次数。例如,假定输入的字符串为“asd asasdfg asd as zx67 asd mklo“,子字符串为“as“,函数返回值是 6。函数 ReadWrite()的功能是实现从文件 in68.dat 中读取两个字符串,并调用函数 findStr(),最后把结果输出到文件 out68.dat 中。注意:部分源程序已给出。请勿改动主函数 main()和其他函数中的任何内容,仅在函数 findStr()的花括号中填入你所
2、编写的若干语句。试题程序#include stdio.h#include string.h#include stdlib.hvoid ReadWrite();int findStr(char * str,char * substr)void main()char str81,substr3;int n;system(“CLS“);printf(“输入原字符串:“);gets(str);printf(“输入子字符串:“);gets(substr);puts(str);puts(substr);n=findStr(str,substr);printf(“n=% d/n“,n);ReadWrite(
3、);void meadWrite()char ch,str81,substr3;int n,len,i=0;FILE * rf, * wf;rf=fopen(“in68.dat“,“r“);wf=fopen(“out68.dat“,“w“);while(i5)fgets(str,80,rf);fgets(substr,10,rf);len=strlen(substr)-i;ch=substrlen;if(ch= =/n|ch= =0xla)substrlen=0;n=findStr(str,substr);fprintf(wf,“% d/n“,n);i + +;fclose(rf);fclos
4、e(wf);(分数:100.00)_三级信息管理技术机试-264 答案解析(总分:100.00,做题时间:90 分钟)1.编写一个函数 findStr(),该函数统计一个长度为 2 的字符串在另一个字符串中出现的次数。例如,假定输入的字符串为“asd asasdfg asd as zx67 asd mklo“,子字符串为“as“,函数返回值是 6。函数 ReadWrite()的功能是实现从文件 in68.dat 中读取两个字符串,并调用函数 findStr(),最后把结果输出到文件 out68.dat 中。注意:部分源程序已给出。请勿改动主函数 main()和其他函数中的任何内容,仅在函数 f
5、indStr()的花括号中填入你所编写的若干语句。试题程序#include stdio.h#include string.h#include stdlib.hvoid ReadWrite();int findStr(char * str,char * substr)void main()char str81,substr3;int n;system(“CLS“);printf(“输入原字符串:“);gets(str);printf(“输入子字符串:“);gets(substr);puts(str);puts(substr);n=findStr(str,substr);printf(“n=% d
6、/n“,n);ReadWrite();void meadWrite()char ch,str81,substr3;int n,len,i=0;FILE * rf, * wf;rf=fopen(“in68.dat“,“r“);wf=fopen(“out68.dat“,“w“);while(i5)fgets(str,80,rf);fgets(substr,10,rf);len=strlen(substr)-i;ch=substrlen;if(ch= =/n|ch= =0xla)substrlen=0;n=findStr(str,substr);fprintf(wf,“% d/n“,n);i + +
7、;fclose(rf);fclose(wf);(分数:100.00)_正确答案:(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) /*如果子字符串的第一个字符等于字符串中的该字符,则继续比较
8、下一个字符*/r+ +;p+ +;elsebreak; /*否则退出循环*/if(* r = =/0) /*如果子字符串在字符串中出现了一次*/n+ +; /*则 n 加 1,进行统计*/str+ +; /*指向字符串中的下一个字符*/return n; /*返回统计结果 n*/)解析:本题主要考查了指针的相关操作。首先,通过外层的 while 循环取字符串的每一个字符,取完字符串的所有字符之后,循环才会终止。用两个字符型指针分别指向两个字符串。逐个将字符串的字符跟子字符串的字符对比,如果相等,则两个指针都自加 1,分别指向两个串的下一个字符。若不相等,则主串的指针加 1,子串的指针重新指向起始位置,继续比较下一个字符。