I've been doing some brushing up on my B-Tree and 2-3-4 tree (B tree with order 4), and I'm attempting to implement this in C#. My question to you is, given that a B-Tree node can contains N-1 number of items and N subtrees, what is the typical representation for one of these nodes? Is it an array, series of linked-lists, or something I've not considered?
+2
A:
For a 2-3-4 tree, it does not really matter. For large orders, you'd use a sorted array and binary search. For variable-size keys like Strings, a trie might be a good idea.
Michael Borgwardt
2010-02-07 22:13:39
A:
Here's an interesting article on MSDN about writing a binary search tree in C#. Not exactly the same as a b-tree but you may find it useful. The author in this case uses a generic Collection base class:
public class Node<T>
{
private T data;
private NodeList<T> neighbors = null;
...
}
public class NodeList<T> : Collection<Node<T>> { ... }
fatcat1111
2010-02-07 22:21:25
binary-tree != B-Tree
Henk Holterman
2010-02-08 11:58:01
Yes, that's why I have in the body of my post (2nd sentence), "Not exactly the same as a b-tree, but you may find it useful." The idea being that the base type for the collection is simply Collection<T>, not a LinkedList or Array like the OP mentioned.
fatcat1111
2010-02-08 19:23:27
+1
A:
Don't try to combine sub-trees and items. You will need 2 arrays or List<>'s.
If your order is fixed i would use 2 arrays. Otherwise, a List<ItemClass>
and a List<SubTree>
Henk Holterman
2010-02-08 12:01:56