Ich denke nicht, dass der Grad eines Baumes ein Standardbegriff in der Graphentheorie oder in Datenstrukturen ist. Ein Grad ist normalerweise eine Eigenschaft eines Knotens / Scheitelpunkts eines Graphen, der die Anzahl seiner einfallenden Kanten angibt. Bei Bäumen berücksichtigt man manchmal nur die Kanten der Kinder.
Ich nehme an, "B-Baum mit einem Mindestgrad von 2" bedeutet, dass jeder Knoten mindestens zwei Kinder hat. Mit anderen Worten, es ist eine Untergrenze für die Anzahl der Kinder. Andererseits bezeichnet die Reihenfolge eines B-Baums den maximalen Knotengrad und ist daher eine Obergrenze.
Degree
repräsentiert die Untergrenze für die Anzahl der Kinder. dh die minimal mögliche Anzahl. Während dasOrder
die Obergrenze für die Anzahl der Kinder darstellt. dh. die maximal mögliche Anzahl. Vielen Dank.Ein B-Tree-Knoten kann mehr als einen Schlüsselwert enthalten, während ein BST-Knoten nur einen enthält. Es gibt Unter- und Obergrenzen für die Anzahl der Schlüssel, die ein Knoten enthalten kann. Diese Grenzen können als feste ganze Zahl ausgedrückt werden, die
t>=2
als Mindestgrad des B-Baums bezeichnet wird.t-1
Schlüssel haben. Jeder interne Knoten außer der Wurzel hat also mindestenst
Kinder.2t-1
Schlüssel enthalten. Daher kann ein interner Knoten höchstens untergeordnete Knoten haben2t
. Wir sagen, dass ein Knoten voll ist, wenn er genau2t-1
Schlüssel enthält .Klicken Sie auf diesen Link , um eine hervorragende Einführung in B-Tree zu erhalten, und auf diesen Link, um einen nachfolgenden und am einfachsten zu schreibenden Algorithmus für B-Tree-Operationen zu erhalten.
quelle
Ich habe bisher drei Möglichkeiten gesehen, B-Baum zu charakterisieren:
Mit dem Grad des B-Baums (entweder minimal wie im CLRS- Algorithmusbuch oder maximal wie im B-Baum-Visualizer ).t
Der Text, auf den in Nasirs Antwort verwiesen wird, folgt genau der Definition des B-Baums, wie in Algorithmen angegeben, mit einer detaillierten Erläuterung der Eigenschaften des Mindestgrads.
Bei und Parametern mit unterer (oberer) Grenze für die Anzahl der Kinder soll der innere Knoten haben (z. B. B-Baum mit entspricht B-Baum mit (beide erlauben 2) –5 Schlüssel pro Knoten),U L = 3 , U = 6 t = 3L. U. L = 3 , U.= 6 t = 3
Mit der Ordnung des B-Baumes , gegeben von Knuth in TAOCP, Vol. 3 so, dass jeder interne Knoten zwischen und Kindern hat.⌈ mm m⌈m2⌉ m
Etwas zusammenfassen:
In Bezug auf den zweiten Teil der OP-Frage gibt es Satz 18.1 in Algorithmen:
quelle
Die Reihenfolge (m) des B-Baums definiert (max und min) Nr. von Kindern für einen bestimmten Knoten.
Grad (t) des B-Baumes definiert (max und min) Nr. von Schlüsseln für einen bestimmten Knoten. Der Grad ist als Mindestgrad des B-Baums definiert.
Ein B-Baum der Ordnung m: Alle internen Knoten außer der Wurzel haben höchstens m nicht leere Kinder und mindestens ⌈m / 2⌉ nicht leere Kinder.
Ein B-Baum mit (minimalem) Grad t:
quelle
Degree
stellt die Untergrenze für die Anzahl der Kinder dar, die ein Knoten im B-Baum haben kann (mit Ausnahme der Wurzel). dh die minimal mögliche Anzahl von Kindern. Während dasOrder
die Obergrenze für die Anzahl der Kinder darstellt. dh. die maximal mögliche Anzahl.B Baumeigenschaften in Bezug auf die Bestellung
NOTE
: Wikipedia gibt auch diese anB Baumeigenschaften in Bezug auf den Grad
B Baumeigenschaften in Bezug auf den Grad
NOTE
::These can also be found in the CLRS book
quelle
quelle
B-Baum-Terminologien sind nicht einheitlich definiert, wo immer ich lese . Die zweideutige Frage ist jedoch, wie die Reihenfolge eines B-Baums lautet. und nicht viel über den Grad eines B-Baumes . Der Grad stammt aus der Graphentheorie, die ihn als die Summe aus In-Grad und Out-Grad dieses Knotens angibt.
Daraus lässt sich schließen, dass der Grad enger mit der Anzahl der Zeiger / Kind zusammenhängt, die ein B-Tree-Knoten anstelle von Schlüsselwerten im Knoten haben kann.
Nach Knuth und Michael J. Folk ist ein B-Baum der Ordnung m ein Baum, bei dem jeder Knoten höchstens m Kinder hat. So vage können wir sagen, dass beide Begriffe im Kontext von B-Tree mehr oder weniger gleichwertig sind.
quelle