有望. 2022-01-26 13:24 采纳率: 100%
浏览 75
已结题

求助。。用count函数计算子串substr在str中出现的次数,为什么零错误运行出来有问题?

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; };
}

  • 写回答

4条回答 默认 最新

  • 关注

    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;
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 1月27日
  • 已采纳回答 1月26日
  • 修改了问题 1月26日
  • 创建了问题 1月26日