Kalaiの2ページのSODAペーパーは、ドントケア(1文字に一致するワイルドカード)を使用したパターンマッチングのためのシンプルで効率的なアルゴリズムを提供します。本質的には、畳み込みと同じくらい簡単です。
しかし、ドントケアで複数のパターンを検索している場合はどうなりますか?それでも、たとえばFFTベースの手法でなんとかしてそれを解決できますか?
Kalaiの2ページのSODAペーパーは、ドントケア(1文字に一致するワイルドカード)を使用したパターンマッチングのためのシンプルで効率的なアルゴリズムを提供します。本質的には、畳み込みと同じくらい簡単です。
しかし、ドントケアで複数のパターンを検索している場合はどうなりますか?それでも、たとえばFFTベースの手法でなんとかしてそれを解決できますか?
回答:
複数パターンの場合、少なくとも強力な指数時間仮説が失敗しない限り、それぞれをスキャンするだけが最善の解決策になる可能性があります。
セット所与ことを思い出しとT 1、T 2、... 、T nは宇宙オーバー[ M ]が存在する場合、我々が決めることができれば、SはIおよびTのjはそのようなことSはI ∪ T J = [ M ]の時間におけるO (N 2 - εポリ(M ))、その後、SETHは失敗、すなわち私たちは、時間のランニングとCNF-SATアルゴリズムを持っている。
セットおよびT 1、T 2、… 、T nが与えられた場合、上記の問題を次のようにバイナリアルファベットを無視するマルチパターンマッチングとしてエンコードします。
(これは、パターンの前処理に多くの時間を使用するアルゴリズムについては何も言っていないことに注意してください。たとえば、パターンの全長で2次式です。)