zoukankan      html  css  js  c++  java
  • hdu 1686 KMP算法

    题意:

      求子串w在T中出现的次数。

    kmp算法详解:http://www.cnblogs.com/XDJjy/p/3871045.html

    #include <iostream>
    #include <cstring>
    #include <string>
    #include <cstdio>
    
    using namespace std;
    int lenp;
    int lens;
    void getnext(int *next, char *p)
    {
        int j = 0, k = -1;
        next[0] = -1;
        while(j < lenp)
        {
    
            if(k == -1 || p[j] == p[k])
            {
                j++;
                k++;
                next[j] = k;
            }
            else
                k = next[k];
        }
    }
    
    char s[1000100], p[10100];
    int next[10100];
    int main(void)
    {
        int N;
        scanf("%d", &N);
        while( N-- )
        {
    
            scanf("%s", p);
            scanf("%s", s);
            lens=(int)strlen(s);
            lenp=(int)strlen(p);
    
            getnext(next, p);
            int i = 0;
            int j = 0;
            int sum = 0;
    
            while(i < lens&&j<lenp)
            {
                //printf("%d %d %c %c
    ",i,j,s[i],p[j]);
                if( j == -1 || s[i] == p[j] )
                {
    
                    i++;
                    j++;
                }
                else
                {
                    j = next[j];
                }
                //printf("#%d %d %c %c
    ",i,j,s[i],p[j]);
                if( j >=lenp)
                {
                    sum++;
                    j = next[j];/////////!!!!!!!!!!
                    //printf("%d %c %c
    ",sum,s[i],p[j]);
                }
            }
            printf("%d
    ", sum);
        }
        return 0;
    }
    View Code
    #include <iostream>
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #include <math.h>
    #include <algorithm>
    using namespace std;
    #define L1 1000005
    #define L2 10005
    
    int next[L2], len1, len2, res;
    char s[L1], p[L2];
    
    void get_next ()
    {
        int j = 0, k = -1;
        next[0] = -1;
        while (j < len2)
        {
            if (k == -1 || p[j] == p[k])
            {
                j++, k++;
                next[j] = k;
            }
            else k = next[k];
        }
    }
    void kmp (int pos)
    {
        int i = pos, j = 0;
        while (i < len1 && j < len2)
        {
            //printf("%d %d %c %c
    ",i,j,s[i],p[j]);
            if (j == -1 || s[i] == p[j])
            {
                i++, j++;
            }
            else j = next[j];
            //printf("#%d %d %c %c
    ",i,j,s[i],p[j]);
            if (j >= len2)
                    res++, j = next[j];    //神奇之处,效率大增
        }
    }
    int main()
    {
        int t;
        scanf ("%d", &t);
        while (t--)
        {
            res = 0;
            scanf ("%s%s", p, s);
            len1 = strlen (s);
            len2 = strlen (p);
            get_next ();
            kmp (0);
            printf ("%d
    ", res);
        }
        return 0;
    }
    View Code
  • 相关阅读:
    Android Handler主线程和一般线程通信的应用分析
    在java中string为什么要设计成final的
    Java中有几种创建对象的方式
    String和StringBuilder、StringBuffer的区别
    正确的二分查找实现
    SSH编写程序中文乱码解决
    lamda表达式
    kmp算法核心代码
    简洁清晰的quicksort核心代码
    [趣题]生成多个质数的幂积序列
  • 原文地址:https://www.cnblogs.com/XDJjy/p/3923097.html
Copyright © 2011-2022 走看看