BZOJ4503: 兩個串(bitset字符串匹配)
阿新 • • 發佈:2018-10-10
max 位置 pan 匹配 str printf 直接 scanf bits
題意
題目鏈接
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\n%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\n", cnt); for(int i = 1; i <= N - M + 1; i++) if(ans[i] == 1) printf("%d\n", i - 1); } /* ababababba a?aba?abba */
BZOJ4503: 兩個串(bitset字符串匹配)