4、 编写一个函数,该函数可以统计一个长度为N的字符串在另一个字符串中出现的次数
。例如,假定输入的字符串为:asd asasdfg asd as zx67 asd mklo,子字符串为:as
,则应输出6。
#include "stdio.h"
#include "string.h"
#include "conio.h"
int fun(char *str,char *substr)
{
int i,n=0,s=strlen(str),t=strlen(substr),*p;
p=substr;
for(i=0;i<s;i++)
{
int j=0,a,b,flag;
a=i;
while ((str!=NULL)&&(substr!=NULL))
{
if (*str++==*substr++)
{
flag=1;
b=i++;//这个用意是,当执行到某步后,不管配对有没有成功,都让for循环从该地方向下开始执行
}
else
{
flag=0;
b=i++;//这个用意是,当执行到某步后,不管配对有没有成功,都让for循环从该地方向下开始执行
continue ;//这里break;也不行
}
}
if(flag)
{
n++;
}
substr=p;
i=b;
}
return n;
}
main()
{
char str[81],substr[3];
int n;
clrscr();
printf("enter 1:");
gets(str);
printf("enter 2:");
gets(substr);
puts (str);
puts(substr);
n=fun(str,substr);
printf("n=%d\n",n);
getch();
}
为什么我的程序执行到最后N都是0;
各位大虾多多指教啊