c语言帮我修改一下。请编写函数fun功能是: 统计substr所指子字符串在str所指字符串中出现的次数

2024-12-03 16:16:46
推荐回答(2个)
回答1:

#include

void fun(char str[ ],char substr[ ],int *count)
{
int i=0,j=0,n=0;
for(;str[i]!='\0';i++)
{
if(substr[j]=='\0')//循环回来的时候,substr[j]有完全匹配的字符串则n+1
{
n++;
j=0;
}
if(str[i]==substr[j]) //当str[i]和substr[j]相等时候
{
j++;
continue; //跳过下面的,直接继续循环
}
else //不相等的时候,把j赋值0
j=0;

}
if(j!=0) n++; //加这一句,因为最后一次匹配时都退出for循环了,就无法n++了
*count=n;
}

int main()

{
char str[80],substr[80];
int count;
gets(str);
gets(substr);
fun(str,substr,&count);
printf("%d\n",count);
return 0;
}

回答2:

if(substr[j]=='\0')循环回来的时候,substr[j]有完全匹配的字符串则n+1
{
n++;
j=0;
}
这个判断是占了一次循环的,你输入的字符串若是123 123 123,估计就是正确的结果了。