KMP求子串出現次數模板

來源:互聯網
上載者:User
#include <stdio.h>#include <string.h>void preKmp(char *src, int m, int *rule){  int i=0,j=-1;  rule[0]=j;  while(i<m){      while(j!=-1 && src[j] != src[i])          j=rule[j];      i++,j++;      if(j>=m)          rule[i]=rule[j-1];      else          rule[i]=j;  }}int recount=0;void kmp(char *src, int m, char *dest, int n){    int rule[10005];    preKmp(src,m,rule);    int i=0, j=0;    while(i<n){        while(j!=-1 && src[j] != dest[i]){            j = rule[j];        }        i++,j++;        if(j==m){            recount++;            j=rule[j];        }    }}char Reg[10005],ori[1000005];int main(){    int t;    scanf("%d",&t);    while (t--)    {        recount=0;        scanf("%s%s",&Reg,&ori);//找出reg在ori中出現的次數        kmp(Reg,strlen(Reg),ori,strlen(ori));        printf("%d\n",recount);    }    return 0;}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.