DFAの移行モノイドメンバーシップ


9

完全なDFAを考えると=QΓδF、我々は、関数の集合を定義することができますfaそれぞれについて、aΓとしてfa:QQfa(q)=δ(q,a)。この概念を単語w=a1,,amおよびf wに一般化できます。 ∘が機能組成物を意味します。さらに我々示す G = { F 、W | wはΓ * }および Gモノイドです。fw=fa1famG={fwwΓ}G

[ Gは通常、標準の教科書では遷移モノイドと呼ばれていますが、ここでは明確にするために定義を再現しています。

質問は、関数与えられた私たちが決めることができ、fはG(理想的に多項式時間で)、そしてこれが事実である場合(すなわち、そこに存在するwのように、F = F W)かどうか、ワット IS多項式のみ、または指数関数的に長くなる可能性がありますか? f:QQfGwf=fww

[確かにそのような単語は指数関数的に長くなる可能性があると思いますが、簡単な例を探しています。]

回答:


9

決定性

それは決定可能です。のみ有限多くの可能な機能がある使用すると、1つの機能ごとの頂点およびエッジと、グラフの到達可能性の問題としてこれをモデル化することができるように、G Hが存在する場合Γは、このようなhは= F AG。次に、関数gG内にあるかどうかをテストすると、gf ϵからグラフで到達可能かどうかをテストすることになります。横一回目を使って、そのような最短の単語を見つけることができます。Qの実行時間は指数関数的かもしれませんf:QQghaΓh=faggGgfϵQけれども。

単語の長さ

そのような最短の単語は指数関数的に長くなる可能性があります。以下はそのようなDFAの例です。ましょう最初のk個の素数を。その後、状態は次の形式になりますI X I { 1 ... K }及びX I{ 0 1 ... P I - 1 }。単項アルファベットでDFAを定義するΓ = { 0p1pkkバツ{1k}バツ{01p1}と遷移関数 δ i x 0 = i x + 1 mod p iです。関数 f 0Q Qは、Γ={0}δバツ0=バツ+1モッドpf0QQ

f0バツ=バツ+1モッドp

今すぐ関数を検討で与えられましたgQQ

gバツ=バツ1モッドp

中国の剰余定理を使用して、n = p 1 × p 2 × × p k1)であり、0 nがそのような単語の中で最も短いことを示すことができます。さらに、| Q | = p 1 + + p kなので、Qのnは指数関数的に大きくなります。g=f0=p1×p2××pk10|Q|=p1++pkQ

したがって、そのような単語を出力する多項式時間アルゴリズムには希望がありません。ただし、Gにあるかどうかを決定する多項式時間アルゴリズムの可能性はまだ残っています。gG

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.