私の再帰的挿入 (c#) の実装を見てください。T(n) = 2*T(n/2) + O(1) があります。O(1) は中心を見つけるためのものです: (l+r)/2。したがって、共謀はO(n)です
public class Tree<T>
{
public class TreeNode<T>
{
public TreeNode<T> Right { get; set; }
public TreeNode<T> Left { get; set; }
public T Data { get; set; }
}
public Tree()
{
Root = new TreeNode<T>();
}
public TreeNode<T> Root { get; set; }
private void InsertSortedListRec(IList<T> items, TreeNode<T> curNode, int l, int r)
{
var mid = (l + r)/2;
curNode.Data = items[mid];
if (mid - 1 >= l)
{
curNode.Left = new TreeNode<T>();
InsertSortedListRec(items, curNode.Left, l, mid - 1);
}
if (mid + 1 <= r)
{
curNode.Right = new TreeNode<T>();
InsertSortedListRec(items, curNode.Right, mid + 1, r);
}
}
public void InsertSortedList(IList<T> items)
{
InsertSortedListRec(items, Root, 0, items.Count - 1);
}
}
インデックス付き配列があると仮定します(リンクリストを配列O(n)に変換できます)