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;
各位大虾多多指教啊
----------------解决方案--------------------------------------------------------
。。。
[此贴子已经被作者于2007-1-7 22:49:24编辑过]
----------------解决方案--------------------------------------------------------
楼主的程序是 二级的题吧
你看看着个行不
#include "stdio.h"
#include "string.h"
#include "conio.h"
int fun(char *str,char *substr)
{
int i,k,j,m,p=0;
char a[10];
k=strlen(substr); /*k是 substr的长度*/
for(i=0;i<=strlen(str);i++)
{
for(j=i,m=0;j<=k+i-1;j++,m++)/*把str里的字符依次给a数组 副值的次数=substr的长度*/
a[m]=str[j];
a[m]='\0';
if((strcmp(a,substr)==0))/*比较他们是否相等*/
p++;
}
return p;
}
main()
{
char str[81],substr[10];
int n;
printf("enter 1:");
gets(str);
printf("enter 2:");
gets(substr);
puts (str);
puts(substr);
n=fun(str,substr);
printf("n=%d\n",n);
}
[此贴子已经被作者于2007-1-7 22:43:31编辑过]
----------------解决方案--------------------------------------------------------
谢谢3楼大哥了
----------------解决方案--------------------------------------------------------