gegeda123 2016-12-11 10:41 采纳率: 0%
浏览 1064
已采纳

一道C语言的题目求解!!

编写函数int fun(char *s1,char *s2),在字符串s1中统计字符串s2出现的次数并返回。若s2在s1中未出现,则返回0。例如:
若输入的字符串s1为:abaaAabcaabbabca,字符串s2为:ab ,则程序输出:n=4
若输入的字符串s1为:abaaAabcaabbabca,字符串s2为:abd,则程序输出:No find
#include
#include
int fun(char *s1,char *s2)
{
}
int main()
{ char a[80],b[80];
  int n;
  printf("Please input the first string:");
  gets(a);
  printf("Please input the second string:");
  gets(b);
  n=fun(a,b);
  if(n==0)
    printf("No find\n");
  else printf("n=%d\n",n);
  return 0;
}

  • 写回答

1条回答 默认 最新

  • Xefvan 2016-12-11 12:20
    关注

    最简单的朴素字符串匹配算法可以实现

    int fun(char* s1, char* s2)
    {
        int num = 0;
        int n = strlen(s1);
        int m = strlen(s2);
        for(int s = 0; s <= n - m; ++s) {
            int j = 0;
            if(s1[s] == s2[j]) {
                int k = 0;
                for(int i = 0; i < m; ++i) {
                    if(s1[s + i] == s2[j + i]) {
                        ++k;
                        continue;
                    }
                    else {
                        break;
                    }
                }
                if(k == m) {
                    ++num;
                }
            }
        }
        if(num == 0)
            return 0;
        return num;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 微信小程序协议怎么写
  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看