バイナリツリーの最小の高さなぜですか?


10

私のJavaクラスでは、さまざまなタイプのコレクションの複雑さについて学習しています。

間もなく、私が読んでいる二分木について議論します。この本は、二分木の最小の高さはであると述べていますが、それ以上の説明はありません。ログ2+11

誰かが理由を説明できますか?


回答:


11

二分木は、非葉ノードに1つまたは2つの子を持ち、葉ノードに0ノードを持ちます。ツリーにはノードがあり、有効なバイナリツリーを形成するようにノードを配置する必要があります。

証明せずに、高さを最大化するには、ノードを線形に配置する必要があります。つまり、各非リーフノードは子を1つだけ持つ必要があります。

                              O 1
                              |
                              O 2
                              |
                              O 3
                              |
                              O 4
                              |
                              O 5
                              |
                              O 6
                              |
                              O 7
                              |
                              O 8

ここで、ノードの数で高さの関係を計算する式は簡単です。場合木の高さは、H = N - 1hh=1

ここで、高さが最小のノードのバイナリツリーを構築しようとすると(常に完全なバイナリツリーに還元可能)、次のレベルに進む前に、できるだけ多くのノードを上位レベルにパックする必要があります。したがって、ツリーは次のツリーの形式をとります。

                              O
                              |1
                              |
                       O------+-----O
                       |2           |3
                       |            |
                   O---+---O    O---+----O
                   |4      |5    6        7
                   |       |
               O---+--O    O
                8      9    10

特定のケース、から始めましょう。=2メートル1

私たちは、知っている

20+21+22++2メートル1=2メートル1

また、レベルは最大で2 iノードを持つことができることを証明するのは簡単です。2

この結果を上記の合計で使用すると、0からmまでの各レベルに対して、2 m1の展開に対応する項2 i 1が存在することがわかります。これは、完全な二分木2 m1ノードが完全に満たされ、高さh 2 m1 = m 1であることを意味します。ここで、h n = nノードの完全な二分木の高さです。0メートル212メートル12メートル1h2メートル1=メートル1h=

この結果を使用すると、。これは、2 m1ノードのツリーが完全に満たされ、したがって2 m1 + 1 = 2 mノードのツリーは、次のレベルの追加ノードに対応する必要があるためです。Mから1だけ高さを高くM - 1、Mh2メートル=メートル2メートル12メートル1+1=2メートルメートルメートル1メートル

これまでに証明したことは、h 2 m + 1= m + 1 、およびh 2 m + 11 = mです。

h2メートル=メートル
h2メートル+1=メートル+1
h2メートル+11=メートル

したがって、、M H N < M + 1Z2メートル<2メートル+1

メートルh<メートル+1

しかし、両側の対数(基数2)を取って、 、M = ログ2nは

メートルログ2<メートル+1
メートル=ログ2

したがって、H N = M = ログ2N [2メートル2メートル+1

h=メートル=ログ2

そして、我々はこの結果を一般化することができ誘導を利用して。Z

ログ2+11ログ2


18

41+12+122+1222

ノード=1+2+22+2++2深さ=Σk=0深さ2k=12深さ+112

ノード=2深さ+11
ノード+1=2深さ+1ログ2ノード+1=ログ22深さ+1=深さ+1ログ2ノード+11=深さ

4

高さを最小に保つには、最後のレベル以外のすべてのレベルを埋める必要があることが簡単にわかります。どうして?それ以外の場合は、最後のレベルのノードを上のレベルの空のスロットに移動するだけです。

今、私はいくつかの不特定の数のBeanがあり、一度に1つのBeanを与えて、可能な限り最小の高さのバイナリツリーを構築するように要求するとします。最後のレベルを完全に満たすか、少なくとも最後のレベルに1つのBeanが含まれるまでに、Beanがなくなる可能性があります。この時点で、あなたは木の高さhを持っているとしましょう。

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