当前位置: 代码迷 >> C语言 >> 高手快来帮帮我
  详细解决方案

高手快来帮帮我

热度:94   发布时间:2007-01-07 21:08:16.0
高手快来帮帮我

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楼大哥了


----------------解决方案--------------------------------------------------------
  相关解决方案