1、三级数据库技术机试-297 及答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.编写一个函数 findStr(),该函数统计一个长度为 2 的字符串在另一个字符串中出现的次数。例如,假定输入的字符串为“asd asasdfg asd as zx67 asd mklo“,子字符串为“as”,函数返回值是 6。函数 ReadWrite()的功能是实现从文件 in40.dat 中读取两个字符串,并调用函数 findstr(),最后把结果输出到文件 out40.dat 中。注意:部分源程序已给出。请勿改动主函数 main()和其他函数中的任何内容,仅在
2、函数 findStr()的花括号中填入你所编写的若干语句。#includestdio.h#includestring.h#includeconio.hint findStr(char *str,char *substr)main ( )char str81,substr3;int n;clrscr();printf(“输入原字符串: “);gets(str);printf (“输入子字符串: “);gets(substr);puts(str);puts(substr);n=findStr(str,substr);printf(“n=%dkn“,n);ReadWrite();ReadWrite(
3、)char ch, str81,substr3;int n,len, i=0;FILE *rf,*wf;rf=fopen(“in40.dat“,“r“);wf=fopen(“out40.dat“,“w“);while(i5)fgets(str,80,rf);fgets(substr,10,rf);len=strlen(substr)-1;ch=substrlen;if(ch=/n|ch=Oxla)substrlen=0;n=findStr(str,substr);fprintf(wf,“%dln“,n);i+;fclose(rf);fclose(wf);(分数:100.00)_三级数据库技术机
4、试-297 答案解析(总分:100.00,做题时间:90 分钟)一、上机题(总题数:1,分数:100.00)1.编写一个函数 findStr(),该函数统计一个长度为 2 的字符串在另一个字符串中出现的次数。例如,假定输入的字符串为“asd asasdfg asd as zx67 asd mklo“,子字符串为“as”,函数返回值是 6。函数 ReadWrite()的功能是实现从文件 in40.dat 中读取两个字符串,并调用函数 findstr(),最后把结果输出到文件 out40.dat 中。注意:部分源程序已给出。请勿改动主函数 main()和其他函数中的任何内容,仅在函数 findSt
5、r()的花括号中填入你所编写的若干语句。#includestdio.h#includestring.h#includeconio.hint findStr(char *str,char *substr)main ( )char str81,substr3;int n;clrscr();printf(“输入原字符串: “);gets(str);printf (“输入子字符串: “);gets(substr);puts(str);puts(substr);n=findStr(str,substr);printf(“n=%dkn“,n);ReadWrite();ReadWrite()char ch,
6、 str81,substr3;int n,len, i=0;FILE *rf,*wf;rf=fopen(“in40.dat“,“r“);wf=fopen(“out40.dat“,“w“);while(i5)fgets(str,80,rf);fgets(substr,10,rf);len=strlen(substr)-1;ch=substrlen;if(ch=/n|ch=Oxla)substrlen=0;n=findStr(str,substr);fprintf(wf,“%dln“,n);i+;fclose(rf);fclose(wf);(分数:100.00)_正确答案:(int findStr
7、(char *str,char*substr)int n;char *p,*r;n=0;while(*str)p=str; /*指针 p 指向字符串首地址*/r=substr; /*指针 r 指向子字符串首地址*/while(*r)if(*r=*p) /*如果子字符串的第一个字符等于字符串中的该字符,则继续比较下一个字符*/ r+;p+;else break; /*否则退出循环*/if(*r=/0) /*如果子字符串在字符串中出现了一次*/n+; /*则 n 加 1,进行统计*/str+; /*指向字符串中的下一个字符*/return n; /*返回 n*/)解析:解析 本题考查的知识点如下:(1)指针的相关操作。(2)强行退出break 的使用。指针是 C 语言中的一个难点。在这里,我们要使用指针实现对数组的访问继而进行字符韵比较。使用数组存放字符串时,存放的字符个数要比数组的容量小 1,因为数组最后一个位置存放的是空格或者结束标志位。我们可利用这一点来判断一个字符串是否已经结束。在循环结构中常常要出现强行退出的情况,这里要使用到 bleak 语句强行退出一层循环。当字符串中的某个字符与子字符串的第一个字符不同时,则将字符串中的下一个字符与子字符串中的第一个字符比较,而不是与子字符串中的第二个字符比较。