count(char *str,char *substr)
{
int x,y,z;
int num=0;
for(x=0;str[x]!=’\n’;x++)
for(y=x,z=0;substr[z]==str[y];z++,y++)
if(substr[z]==NULL)
{num++; break; };
}
求助。。用count函数计算子串substr在str中出现的次数,为什么零错误运行出来有问题?
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
4条回答 默认 最新
技术专家团-小桥流水 2022-01-26 14:15关注1.字符结束符是\0,不是\n,\n是回车符
2.如果substr在str的中间部分,for循环中使用substr[z]==str[y]作为条件的时候,当substr到了末尾的时候,是不会进入for循环的。代码修改如下:
int count(char *str,char *substr) { int x,y,z; int num=0; for(x=0;str[x] != '\0';x++) { for(y=x,z=0; substr[z] != '\0'&& substr[z]==str[y];y++,z++); //注意这里的分号 if(substr[z] == '\0') num++; } return num; }本回答被题主选为最佳回答 , 对您是否有帮助呢?评论 打赏 举报 编辑记录解决 2无用