问题 多项选择题

fclose(wf);

答案

参考答案:
int findStr(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加A,进行统计*/
str++; /*指向字符串中的下一个字符*/
}
return n; /*返回n*/
}

解析:本题考查的知识点如下:
(1)指针的相关操作。
(2)强行退出——break的使用。
指针是C语言中的一个难点。在这里,我们要使用指针实现对数组的访问继而进行字符的比较。使用数组存放字符串时,存放的字符个数要比数组的容量小1,因为数组最后—个位置存放的是空格或者结束标志位。我们可利用这一点来判断一个字符串是否已经结束。在循环结构中常常要出现强行退出的情况,这里要使用到break语句强行退出一层循环。当字符串中的某个字符与子字符串的第一个字符不同时,则将字符串中的下一个字符与子字符串中的第一个字符比较,而不是与子字符串中的第二个字符比较。

填空题
填空题