int main() { //freopen("in.txt","r",stdin); //freopen("out.txt","w",stdout); int n,m; long long val; int len; long long seed=13131313; long long base=1; bool ok; myh.init(); scanf("%d %d",&n,&m); while(n--) { scanf("%s",s); myh.insert(myh.hash(s)); } while(m--) { base=1; ok=0; scanf("%s",s); val=myh.hash(s); len=strlen(s); for(int i=len-1;i>=0;--i) { for(int j=0;j<3;++j) if(j!=s[i]-'a') if(myh.match(((val+base*(j-(s[i]-'a'))%MOD+MOD)%MOD))) { ok=1; break; } if(ok) break; base=(base*seed)%MOD; } if(ok) puts("YES"); else puts("NO"); } return 0; }
void init() { hm.init(); ans = 0; last = 0; }