T(n)= 2T(n / 2)+ log nを再帰ツリー法で解く


9

私は再発関係を解決していました。最初の再発関係は

T(n)=2T(n/2)+n

これの解は、マスター定理または再帰ツリー法で見つけることができます。再帰ツリーは次のようになります。

![ここに画像の説明を入力してください

解決策は次のとおりです。

T(n)=n+n+n+...+nlog2n=k times=Θ(nlogn)

次に私は次の問題に直面しました:

T(n)=2T(n/2)+logn

私の本は、マスター定理またはいくつかの代替アプローチによってさえ、この再帰は解を持つことを示しています。これは上記のツリーと同じ構造ですが、各呼び出しで作業を実行する点のみが異なり。ただし、この問題に対して上記の同じアプローチを使用することはできません。Θ(n)logn

回答:


5

再帰関係の非再帰的な用語は、副問題の解をマージする作業です。(バイナリ)再帰ツリーのレベルは、サイズ部分問題が含まれているため、最初にレベル合計作業量を見つけ、次にこの作業をすべてにわたって要約する必要がありますツリーレベル。k2kn2kk

仕事が一定であれば、例えば、、その後、レベル上の総仕事あろう、および総時間以下の合計により与えられます。Ck2kCT(n)

T(n)=k=1log2n2kC=C(2log2n+12)=Θ(n)

ただし、問題のサイズに応じて作業が対数的に増加する場合は、ソリューションを正確に計算する必要があります。シリーズは次のようになります。

T(n)=log2n+2log2(n2)+4log2(n4)+8log2(n8)+....log2n times

非常に複雑な合計になります。

T(n)=log2n+k=1log2n2klog2(n2k)

一時的にと表記し、上記の合計を簡略化します。m=log2n

k=1m2klog2(n2k)==k=1m2k(log2nk)==log2nk=1m2kk=1mk2k==log2n(2m+12)(m2m+12m+1+2)

ここでは、Wolfram | Alphaオンラインシンボリック代数計算機からの合計の式を使用しました。次に、を戻す必要があります。k=1mk2kmlog2n

T(n)=log2n+2nlog2n2log2n2nlog2n+2n2
=2nlog2n2=Θ(n)

QED


1
いまいましい質問をするのにすごく愚かな間違いをした。今修正されました。ただし、シリーズの内容が互いにキャンセルし合う方法を取得することはできません ..これはあなたが来るシリーズです右で?で試して、。ここで何が問題なのですか?20log2n20+21log2n21+22log2n22+...+2log2nlog2n2log2n=log2n+2log2n2+4log2n4+...+nlog21n=8log28+2log24+4log22+8log21=3+4+4=11
2016年

@anir-等式を使用log2(n2k)=log2nk
HEKTO

1
そのシリーズが : ' Θ(n)
ta

@anir-私は私の答えを拡張します
HEKTO 2016年

@HEKTO上記のコメントのequを解決しても、nlog(n)が返されますか?私はたくさん試しました。ここで私を助けてくれませんか?
roottraveller 2017
弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.