输入一个字符串,计算字符串中子串出现的次字数
有两种写法,一种利用了strstr函数,另一种用了for的嵌套循环
第一种
#include <stdio.h>
#include <string.h>
void Zc(char *str,char *str1);
int main ()
{
char a[60];
char b[20];
printf(“Input str:”);
gets(a);
puts(a);
printf(“Input str1:”);
gets(b);
puts(b);
Zc(a,b);
return 0;
}
void Zc(char *str,char *str1)
{
int count=0;
char *p;
do{
p = strstr(str,str1);
if(p!=NULL)
{
str=p+1;
count++;
}
}while(p!=NULL);
printf("%d",count);
printf("\n");
}
第二种:
#include <stdio.h>
int main()
{
int i,j;
char a[20];
char b[10];
printf(“Input a:”);
gets(a);
printf(“Input b:”);
gets(b);
int count=0;
for(i=0;a[i]!=’\0’;i++)
{
for(j=0;a[i+j]!=0&&b[j]!=0;j++)
{
if(a[i+j]!=b[j])
{
break;
}
else if(b[j+1]==’\0’)
{
count++;
}
}
}
printf("%d",count);
printf("\n");
}