第二行包含一個數字,表示大小寫敏感的選項,當數字爲0時表示大小寫不敏感,當數字爲1時表示大小寫敏感。
第三行包含一個整數n,表示給出的文字的行數。
接下來n行,每行包含一個字符串,字符串由大小寫英文字母組成,不含空格和其他字符。
1
5
HelloWorld
HiHiHelloHiHi
GrepIsAGreatTool
HELLO
HELLOisNOTHello
HiHiHelloHiHi
HELLOisNOTHello
1<=n<=100,每個字符串的長度不超過100。
#include<iostream>
#include<algorithm>
#include<string>
using namespace std;
#define MAX 100+5
const int cap = 'a' - 'A';
int nx[MAX];
void pre(string s){
nx[0] = -1;
int j = 0, k = -1;
while (j < s.length()){
if ((k == -1) || (s[j] == s[k])){
j++;
k++;
nx[j] = k;
}
else k = nx[k];
}
}
bool kmp(string s,string cs,int c){
int z = 0;
for (int i = 0; i <= s.length(); i++){
if (z >= cs.length()){
return true;
}
if (i == s.length()) return false;
if (s[i] == cs[z] || abs(s[i]-cs[z])==cap*c){
z++;
}
else{
while (nx[z] != -1 && (s[i] != cs[z] && abs(s[i] - cs[z]) != cap*c)){ // 大小寫
z = nx[z];
}
}
}
}
int main(){
string s;
cin >> s;
pre(s);
int c,n;
cin >> c >> n;
while (n--){
string ss;
cin >> ss;
if (kmp(ss, s, abs(c-1))){
cout << ss << endl;
}
}
return 0;
}