本文整理匯總了C#中BinarySearchTree.TryGetNode方法的典型用法代碼示例。如果您正苦於以下問題:C# BinarySearchTree.TryGetNode方法的具體用法?C# BinarySearchTree.TryGetNode怎麽用?C# BinarySearchTree.TryGetNode使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類BinarySearchTree
的用法示例。
在下文中一共展示了BinarySearchTree.TryGetNode方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。
示例1: TestGetPredecessor
public void TestGetPredecessor()
{
var tree = new BinarySearchTree<int>();
var size = 10;
Node<int> node = null;
for (int i = 0; i < size; i++)
{
node = tree.Add(i);
}
for (int i = size - 1; i >= 0; i--)
{
tree.TryGetNode(i, out node);
var prev = tree.Predecessor(node);
if (i > 0)
Assert.AreEqual(node.Value - 1, prev.Value);
else
Assert.IsNull(prev);
}
}
示例2: TestTryGet
public void TestTryGet()
{
var tree = new BinarySearchTree<int>();
var size = 10;
for (int i = 0; i < size; i++)
{
tree.Add(i);
}
Node<int> node;
for (int i = 0; i < size; i++)
{
Assert.IsTrue(tree.TryGetNode(i, out node));
}
Assert.IsFalse(tree.TryGetNode(1000, out node));
}
示例3: TestGetSuccessor
public void TestGetSuccessor()
{
var tree = new BinarySearchTree<int>();
var size = 10;
Node<int> node = null;
for (int i = 0; i < size; i++)
{
node = tree.Add(i);
}
for (int i = 0; i < size; i++)
{
tree.TryGetNode(i, out node);
var next = tree.Successor(node);
if (i < size - 1)
Assert.AreEqual(node.Value + 1, next.Value);
else
Assert.IsNull(next);
}
}
示例4: TestDelete
public void TestDelete()
{
var tree = new BinarySearchTree<int>();
var size = 10;
for (int i = 0; i < size; i++)
{
tree.Add(i);
}
Assert.AreEqual(tree.Count, size);
Node<int> node;
for (int i = 0; i < size; i++)
{
tree.TryGetNode(i, out node);
tree.Remove(node);
}
Assert.AreEqual(tree.Count, 0);
Assert.IsTrue(tree.IsEmpty);
}