C语言统计substr所指的子符串在str所指的字符串中出现的次数

例如,若字符串为aaaskaaas,子字符串为as,则应输出2。#include<stdio.h>intfun(char*str,char*substr){inti,j,... 例如,若字符串为aaas kaaas,子字符串为as,则应输出2。
#include <stdio.h>
int fun (char *str,char *substr)
{ int i,j,k,num=0;
/************found************/
for(i = 0;str[i];i++)
for(j=i,k=0;substr[k]==str[j];k++,j++) || k++,j++有什么用?
/************found************/
if(substr[k+1]=='\0')
{ num++;
break; }
return num;
}
main()
{
char str[80],substr[80];
printf("Input a string:") ;
gets(str);
printf("Input a substring:") ;
gets(substr);
printf("%d\n",fun(str,substr));
}
补充:substr[k]==str[j]是比较两个字符数组中的字符吗? 如果是,只比较字符怎么可能得到结果?
我的疑问是两个字符数组比较的内容是字符还是字符串?
展开
 我来答
enjoynetwind
推荐于2018-03-13 · 超过25用户采纳过TA的回答
知道答主
回答量:56
采纳率:0%
帮助的人:56.4万
展开全部
代码在str中不断的扫描substr,当找到第一个相同字符时,则循环比较str与substr剩余的字符串,如果substr中的所有字符都在str中出现(通过substr[k+1] == '\0'判断substr是否已判断到最后一个字符),则判断为找到一次substr的完全匹配,把发现次数加1(num++).然后回到第一层循环,直到扫描完str的每个字符(通过第一层循环中的str[i]是否为0判断).
wofgsdklgjW10E
2014-07-18 · TA获得超过121个赞
知道答主
回答量:117
采纳率:0%
帮助的人:117万
展开全部
从 str[] 长字符串里 找 substr[] 目标字符串,短字符串 出现的个数。
for(i = 0;str[i];i++) // 依次从 第 i 个位置 开始 找。
for(j=i,k=0;substr[k]==str[j];k++,j++)
// j 是 str 里的字符位置,j=i+0,i+1,i+2 ....
// k 是 substr 里的字符位置, k=0,1,2,...
这句 j 循环 是 从 j=i+0 开始找起,只要 substr[k]==str[j] 就往下比较,
循环体 if(substr[k+1]=='\0'){ break; }
如果substr[] 里,下一个字符 是 字符串结束符,表示 目标字符串已循环找到尾巴了,也就是 找到了。于是 break -- 结束本次 循环。结束前 num++ 就是统计 直到目前为止,一共找到了 几个 目标字符串。
-------
你可以用
char str[]="abc123abc"; char substr[]="abc";
去调用, 添加一些中间打印,看看是如何循环和比较的。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式