题目:下面的函数统计子字符串substr在字符串str中出现的次数,如果substr在str中不出现, 则返回值0。
/*题目:下面的函数统计子字符串substr在字符串str中出现的次数,如果substr在str中不出现,则返回值0。请完成该函数。格式:int?str_count(ch...
/*题目:下面的函数统计子字符串substr在字符串str中出现的次数,如果substr在str中不出现,
则返回值0。请完成该函数。格式:
int?str_count(char?*substr,?char?*str)
输出结果见图:样张.JPG
-------------------------------------------------------*/
#include <iostream>
#include <cstring>
using namespace std;
/**********Program**********/
int str_count(char *substr, char *str){
int i,j,c,k;
for(i=j=c=0;;i++){
if(substr[j]==str[i])
for(j=0,k=i;;k++,j++){
if(substr[j]=='\0')
{ c++;
break;}
if(substr[j]!=str[k])
break;
}j=0;
if(str[i]=='\n')break;
}
return c;}
/**********??End??**********/
void main(void)
{
char ss[100];
char *s="ABCDabcd1234+-*/XYZxyz/ABCDabcd1234+-*/Aa1 ABCDabcd";
cout<<"母串="<<s<<endl;
cin.getline(ss,99);
cout<<"子串在母串中共出现"<<str_count(ss,s)<<"次"<<endl;
}
谁可以帮我看一下,编译可以通过,但是运行结果不对
不要写个新的给我,我只是想知道自己错在哪里 展开
则返回值0。请完成该函数。格式:
int?str_count(char?*substr,?char?*str)
输出结果见图:样张.JPG
-------------------------------------------------------*/
#include <iostream>
#include <cstring>
using namespace std;
/**********Program**********/
int str_count(char *substr, char *str){
int i,j,c,k;
for(i=j=c=0;;i++){
if(substr[j]==str[i])
for(j=0,k=i;;k++,j++){
if(substr[j]=='\0')
{ c++;
break;}
if(substr[j]!=str[k])
break;
}j=0;
if(str[i]=='\n')break;
}
return c;}
/**********??End??**********/
void main(void)
{
char ss[100];
char *s="ABCDabcd1234+-*/XYZxyz/ABCDabcd1234+-*/Aa1 ABCDabcd";
cout<<"母串="<<s<<endl;
cin.getline(ss,99);
cout<<"子串在母串中共出现"<<str_count(ss,s)<<"次"<<endl;
}
谁可以帮我看一下,编译可以通过,但是运行结果不对
不要写个新的给我,我只是想知道自己错在哪里 展开
2个回答
展开全部
楼主注意使用下面的函数时,输入的字符串必须以'\0'结尾!!
#include <string.h>
int str_count(char *substr, char *str)
{
int sum,len;
char * p;
len = strlen(substr);
if(len<1)
return -1;
for(sum=0,p=str;;)
{
p = strstr(p,substr);
if(p!=NULL)
{
sum++;
p+=len;
}
else
break;
}
return sum;
}
#include <string.h>
int str_count(char *substr, char *str)
{
int sum,len;
char * p;
len = strlen(substr);
if(len<1)
return -1;
for(sum=0,p=str;;)
{
p = strstr(p,substr);
if(p!=NULL)
{
sum++;
p+=len;
}
else
break;
}
return sum;
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询