2012-01-02 4 views
3

各ドアには多数の磁性プレートがあります。すべてのプレートには1つの単語が書かれています。プレートは、すべての単語が前の単語が終わるのと同じ文字で始まるような順序で配置する必要があります。たとえば、acm "という語の後に" "というモトローラという語を続けることができます。オイラーパス、アレンジワード

例: skenzo logicboxes orderbox

ANS:私はこの問題はオイラー路に関連している知っている可能

を注文します。しかし、私はそれを実装することができません。誰かがそれをどのように実装できるか教えてもらえますか?どのようにグラフを作成し、どのノードを接続する必要があるかを意味します。私は隣接行列を使わなければならないが、どのノードを接続しなければならないのか知っている。

+0

満足のいくものでも正しいものでもないと回答を受け入れるのはなぜですか? – dejavu

+1

SPOJ質問? – st0le

+0

私はあなたが不満足であるか間違った答えを受け入れることを示唆していません。そのコメントを書いたときには、10の質問、8つの回答、および受け入れがありませんでした。それは人々があなたからの新しい質問に答えるのを妨げる傾向があります。私は、あなたが今(あなたが少し担当者を増やして)助けてくれたコミュニティー(回答が何が働いているかを見ることができる)の回答を受け入れたことを知っています。 –

答えて

3

私は正しく覚えています。他の人とは違って、あなたが望むのはオイラーの道であり、ハミルトニアンではないということに同意します。結果のグラフでは、単語は頂点の端(最初の文字から最後まで)と文字(ASCIIでは 'a'から 'z'までの小文字の文字のみ)です。

実際には、あなたが望むのはパスそのものではなく、存在するかどうかを知りたいだけです。したがって、グラフ上にオイラーパスが存在するために必要かつ十分な条件が必要です。

明らかに、このようなパスが存在するためには、グラフを接続する必要があります。 ユニオンで効率的にそれを見つけることができますを見つける。
このようなパスが存在すると、頂点の内外の条件が課されます。これらの条件を正しく定式化すれば、a)必要十分な、b)確認が容易です。

自分で条件を見つけるのは楽しいですが、オイラーパスについてはウィキペディアの記事で見つけることもできます。

+0

文字がなぜ頂点になるのか理解できません。小さな事例を教えてください。解決策はプログラムのために利用可能ですが、なぜ私の心の中にコンセプトが得られないのか分からない。私が思ったのは、単語が 'acm'で、別の単語が 'moto'だと仮定した場合、acmは有向グラフでモトに接続されています。どうぞご理解ください。 – dejavu

+1

各単語は、最初の文字から最後の文字までのエッジで、 'recent〜>(r-> t)'、 'radar〜>(r-> r)'などです。だから、26の頂点とエッジのないグラフから始め、エッジが来るように追加します。すべてのエッジが記録されると、エッジのないすべての頂点が破棄されます。それはあなたが調査しなければならないグラフです。 –

+0

グラフは方向付けされているか無向であるか? – gsdf

0

最初のシンボルと最後のシンボルのASCIIコードをグラフの頂点として使用できます。頂点の順序付けにDFSを使用し、すべての頂点が順序付けされているかどうかを確認することができます。そうであれば、すべての言葉よりもその順序で並べることができます。