zoukankan      html  css  js  c++  java
  • BZOJ4503: 两个串(bitset字符串匹配)

    题意

    题目链接

    Sol

    Orz xudyh

    F个毛T啊。。直接bitset一波就赢了啊。。。(虽然复杂度很假)

    就是记录匹配串中每个元素出现的位置,将第(i)个位置的bitset右移(i)位后与起来

    最后找1出现的位置就行了

    复杂度:(O(frac{n^2}{32}))

    #include<bits/stdc++.h>
    using namespace std;
    const int MAXN = 1e5 + 10;
    int N, M, cnt;
    char S[MAXN], T[MAXN];
    bitset<MAXN> B[28];
    main() {
        scanf("%s
    %s", S + 1, T + 1);
        N = strlen(S + 1); M = strlen(T + 1);
        for(int i = 1; i <= N; i++) B[S[i] - 'a'].set(i);
        bitset<MAXN> ans; ans.set();
        for(int i = 1; i <= M; i++) if(T[i] != '?') ans &= (B[T[i] - 'a'] >> (i - 1));
        for(int i = 1; i <= N - M + 1; i++) if(ans[i] == 1) cnt++; printf("%d
    ", cnt);
        for(int i = 1; i <= N - M + 1; i++) if(ans[i] == 1) printf("%d
    ", i - 1);
    }
    /*
    ababababba
    a?aba?abba
    */
    
  • 相关阅读:
    第十一次作业
    第十次作业
    第九次作业
    第八次作业
    第七次作业
    第六次作业
    第五次作业
    java第三次作业
    Java第二次作业
    Java第一次作业
  • 原文地址:https://www.cnblogs.com/zwfymqz/p/9764606.html
Copyright © 2011-2022 走看看