當前位置: 首頁>>代碼示例>>C#>>正文


C# BinarySearchTree.Remove方法代碼示例

本文整理匯總了C#中BinarySearchTree.Remove方法的典型用法代碼示例。如果您正苦於以下問題:C# BinarySearchTree.Remove方法的具體用法?C# BinarySearchTree.Remove怎麽用?C# BinarySearchTree.Remove使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在BinarySearchTree的用法示例。


在下文中一共展示了BinarySearchTree.Remove方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: KeyValuePair

        public void KeyValuePair()
        {
            var tree = new BinarySearchTree<int, string>
                           {
                               {4, "4"},
                               {6, "6"},
                               {2, "2"},
                               {5, "5"},
                               {19, "19"},
                               {1, "1"}
                           };

            Assert.AreEqual(tree.Count, 6);

            Assert.IsTrue(tree.ContainsKey(4));
            Assert.IsTrue(tree.ContainsKey(6));
            Assert.IsTrue(tree.ContainsKey(2));
            Assert.IsTrue(tree.ContainsKey(5));
            Assert.IsTrue(tree.ContainsKey(19));
            Assert.IsTrue(tree.ContainsKey(1));

            Assert.IsFalse(tree.Remove(new KeyValuePair<int, string>(20, "20")));

            Assert.IsTrue(tree.Remove(new KeyValuePair<int, string>(4, "4")));
            Assert.AreEqual(tree.Count, 5);

            Assert.IsFalse(tree.ContainsKey(4));
            Assert.IsTrue(tree.ContainsKey(6));
            Assert.IsTrue(tree.ContainsKey(2));
            Assert.IsTrue(tree.ContainsKey(5));
            Assert.IsTrue(tree.ContainsKey(19));
            Assert.IsTrue(tree.ContainsKey(1));
        }
開發者ID:havok,項目名稱:ngenerics,代碼行數:33,代碼來源:Remove.cs

示例2: Main

    // Define the data structure binary search tree with operations for
    // "adding new element", "searching element" and "deleting elements".
    // Implement the standard methods from System.Object – ToString(), Equals(…), GetHashCode()
    // and the operators for comparison  == and !=.
    // Add and implement the ICloneable interface for deep copy of the tree.
    // Implement IEnumerable<T> to traverse the tree.
    internal static void Main()
    {
        // Create new binary search tree
        BinarySearchTree<string> tree = new BinarySearchTree<string>();

        // Test adding new element
        tree.Insert("Telerik");
        tree.Insert("Google");
        tree.Insert("Microsoft");
        tree.Insert("Facebook");
        tree.Insert("Twitter");

        // Test ToString()
        Console.WriteLine("Tree: {0}", tree);

        // Test searching element
        Console.WriteLine("Tree contains Telerik? -> {0}", tree.Contains("Telerik"));
        Console.WriteLine("Tree contains IBM? -> {0}", tree.Contains("IBM"));

        // Test deleting element
        tree.Remove("Telerik");
        Console.WriteLine("Tree: remove Telerik");
        Console.WriteLine("Tree: {0}", tree);

        // Test GetHashCode
        Console.WriteLine("Tree hash code = {0}", tree.GetHashCode());

        // Test Equals
        var otherTree = new BinarySearchTree<string>();
        otherTree.Insert("Google");
        Console.WriteLine("\nOther tree: {0}", otherTree);
        Console.WriteLine("tree.Equals(otherTree) -> {0}", tree.Equals(otherTree));

        // Test '=='
        Console.WriteLine("Other tree: insert Microsoft, Facebook, Twitter");
        otherTree.Insert("Microsoft");
        otherTree.Insert("Facebook");
        otherTree.Insert("Twitter");
        Console.WriteLine("Other tree: {0}", otherTree);
        Console.WriteLine("tree.Equals(otherTree) -> {0}", tree.Equals(otherTree));

        // Test IEnumerable<T> to traverse the tree
        Console.WriteLine("\nforeach (var node in tree):");
        foreach (var node in tree)
        {
            Console.WriteLine(node);
        }

        // Test deep copy of the tree.
        var treeClone = tree.Clone();
        Console.WriteLine("\ntreeClone: {0}", treeClone);
        tree.Remove("Google");
        Console.WriteLine("Original tree: remove Google");
        Console.WriteLine("treeClone: {0}", treeClone);
    }
開發者ID:MarKamenov,項目名稱:TelerikAcademy,代碼行數:61,代碼來源:Program.cs

示例3: Main

    static void Main()
    {
        BinarySearchTree<int> bTree = new BinarySearchTree<int>();
        AddSomeElements(bTree);
        bTree.PrintTree();
        Console.WriteLine("\n\nRemove 20 and 17\n\n");
        bTree.Remove(20);
        bTree.Remove(17);
        bTree.PrintTree();

        Console.Read();
    }
開發者ID:kaloyan-penkov,項目名稱:SoftUni,代碼行數:12,代碼來源:Starter.cs

示例4: RemoveTest

        public void RemoveTest()
        {
            var bst = new BinarySearchTree<int>() { 10, 15, 5, 4, 7, 20, 14, 0, -5, -8, -2, -1 };
            bst.Remove(20);
            bst.Remove(0);
            bst.Remove(10);

            // TODO: Dump as array then compare against expected array
            Assert.IsFalse(bst.Contains(20), "Did not remove element correctly");
            Assert.IsFalse(bst.Contains(0), "Did not remove element correctly");
            Assert.IsFalse(bst.Contains(10), "Did not remove root element correctly");
        }
開發者ID:jojojojochen,項目名稱:Algorithm-Implementations,代碼行數:12,代碼來源:BinarySearchTreeTests.cs

示例5: BinaryTreeAlgorithms_Test

        public void BinaryTreeAlgorithms_Test()
        {
            var tree1 = new BinarySearchTree<int>();
            tree1.Add(24);
            tree1.Add(12);
            tree1.Add(15);
            tree1.Add(67);
            tree1.Add(32);
            tree1.Add(13);
            tree1.Add(89);
            tree1.Add(9);

            tree1.Remove(13);
            tree1.Remove(24);
            //Assert.IsTrue(tree1.PathSum(tree1.Root(), 45));
            //Assert.IsTrue(tree1.PathSum(tree1.Root(), 51));
            //Assert.IsFalse(tree1.PathSum(tree1.Root(), 42));

            //Assert.AreEqual(8, tree1.Size(tree1.Root()));

            //Assert.AreEqual(9, tree1.Minimum(tree1.Root()));

            //Assert.AreEqual(89, tree1.Maximum(tree1.Root()));

            //Assert.IsTrue(BinaryTree.AreTwoTreesEqual(tree1.Root(), tree2.Root()));

            Console.WriteLine("Inorder traversal ");
            tree1.Inorder(tree1.Root);
            Console.WriteLine(" ");

            TreeAlgorithms<int>.Mirror(tree1.Root);

            Console.WriteLine("Inorder traversal of the Mirror tree");
            tree1.Inorder(tree1.Root);
            Console.WriteLine(" ");

            Console.WriteLine();
            Console.WriteLine("Preorder traversal");
            tree1.Preorder(tree1.Root);
            Console.WriteLine(" ");

            Console.WriteLine();
            Console.WriteLine("Postorder traversal");
            tree1.Postorder(tree1.Root);
            Console.WriteLine(" ");
        }
開發者ID:SaurabhNijhawan,項目名稱:CSharpAlgorithmsAndDataStructures,代碼行數:46,代碼來源:BinaryTreeAlgorithmsTests.cs

示例6: Main

        /// <summary>
        /// Runs a basic test of a Binary Search Tree
        /// </summary>
        static void Main(string[] args)
        {
            // ==== Assign ==== //
            BinarySearchTree<int> bTree = new BinarySearchTree<int>();

            // ==== Act ==== //
            {
                // Insert
                bTree.Insert(50);
                bTree.Insert(30);
                bTree.Insert(70);
                bTree.Insert(15);
                bTree.Insert(45);
                bTree.Insert(55);
                bTree.Insert(85);
                bTree.Insert(19);
                bTree.Insert(75);
                bTree.Insert(77);
                bTree.Insert(17);

                // Remove
                bTree.Remove(85);
                bTree.Remove(70);
            }

            // ==== Assert ==== //
            {
                Console.WriteLine("Does it contain 55: " + bTree.Contains(55));

                // Draw Tree
                Console.WriteLine("\nDisplay the tree:");
                Console.WriteLine(bTree.Display());
                PrintOrdered(bTree);
            }

            // Wait for input before closing.
            Console.ReadLine();
        }
開發者ID:Caresilabs,項目名稱:MAH_DataStructures,代碼行數:41,代碼來源:Program.cs

示例7: Main

 static void Main()
 {
     BinarySearchTree<string> tree =
         new BinarySearchTree<string>();
     tree.Insert("Telerik");
     tree.Insert("Google");
     tree.Insert("Microsoft");
     tree.Insert("ATNT");
     tree.Insert("Blizoo");
     tree.Insert("MTel");
     tree.Insert("ZaraLab");
     tree.Insert("Yahoo");
     tree.PrintTreeDFS(); // Google Microsoft Telerik
     Console.WriteLine(tree.Contains("Telerik")); // True
     Console.WriteLine(tree.Contains("IBM")); // False
     tree.Remove("Telerik");
     Console.WriteLine(tree.Contains("Telerik")); // False
     tree.PrintTreeDFS(); // Google Microsoft
 }
開發者ID:stansem,項目名稱:SoftUni,代碼行數:19,代碼來源:OrderedSetTest.cs

示例8: Main

        private static void Main(string[] args)
        {
            BinaryTree bt = new BinarySearchTree();

            bt.Insert(6);
            bt.Insert(2);
            bt.Insert(8);
            bt.Insert(1);
            bt.Insert(5);
            bt.Insert(10);
            bt.Insert(3);
            bt.Insert(4);

            bt.Remove(1);
            bt.Remove(2);
            bt.Remove(3);
            bt.Remove(4);
            bt.Remove(5);
            bt.Remove(6);
            bt.Remove(8);
            bt.Remove(10);
        }
開發者ID:aesamson,項目名稱:TestApp,代碼行數:22,代碼來源:Program.cs

示例9: TestTreeCount

        public void TestTreeCount()
        {
            var tree = new BinarySearchTree<int>();
            var size = 100;

            Node<int> node = null;
            for (int i = 0; i < size; i++)
            {
                node = tree.Add(i);
            }

            Assert.AreEqual(tree.Count, size);

            tree.Remove(node);

            Assert.AreEqual(tree.Count, size - 1);

            tree.Add(101);

            Assert.AreEqual(tree.Count, size);
        }
開發者ID:deva666,項目名稱:BinarySearchTree,代碼行數:21,代碼來源:BinaryTreeTests.cs

示例10: RemoveNodeNotFoundTest

        public void RemoveNodeNotFoundTest()
        {
            BinarySearchTree<int> bst = new BinarySearchTree<int> {10, 7, 12};

            Assert.IsFalse(bst.Remove(4));
        }
開發者ID:taoxiease,項目名稱:asegrp,代碼行數:6,代碼來源:BinarySearchTreeTest.cs

示例11: RemoveTreeHasNoItemsTest

        public void RemoveTreeHasNoItemsTest()
        {
            BinarySearchTree<int> actual = new BinarySearchTree<int>();

            actual.Remove(10);
        }
開發者ID:taoxiease,項目名稱:asegrp,代碼行數:6,代碼來源:BinarySearchTreeTest.cs

示例12: BinarySearchTreeTests_Remove4

        public void BinarySearchTreeTests_Remove4()
        {
            IBinarySearchTree<int, string> tree = new BinarySearchTree<int, string>();
            tree.Insert(10, "John");
            tree.Insert(5, "Clark");
            tree.Insert(13, "Pitty");
            tree.Insert(17, "Lilly");
            tree.Insert(8, "Jack");
            tree.Insert(0, "Lui");
            tree.Insert(16, "Petr");

            int[] expectedKeys = { 8, 10, 16, 17 };

            bool actualResult = tree.Remove(5) && tree.Remove(13) && tree.Remove(0);
            var actualKeys = tree.TraverseInOrder().Select(n => n.Key);

            Assert.IsTrue(actualResult);
            Assert.IsTrue(tree.Count == expectedKeys.Length);
            Assert.IsTrue(expectedKeys.Except(actualKeys).Count() == 0);
            Assert.IsTrue(actualKeys.Except(expectedKeys).Count() == 0);
        }
開發者ID:ZuTa,項目名稱:Algorithms,代碼行數:21,代碼來源:BinarySearchTreeTests.cs

示例13: BinarySearchTreeTests_Remove0

        public void BinarySearchTreeTests_Remove0()
        {
            IBinarySearchTree<int, string> tree = new BinarySearchTree<int, string>();

            bool actualResult = tree.Remove(10);

            Assert.IsFalse(actualResult);
        }
開發者ID:ZuTa,項目名稱:Algorithms,代碼行數:8,代碼來源:BinarySearchTreeTests.cs

示例14: RemoveLeafValueGreaterThanOrEqualToParentTest

        public void RemoveLeafValueGreaterThanOrEqualToParentTest()
        {
            BinarySearchTree<int> bst = new BinarySearchTree<int> {10, 7, 12};

            Assert.IsTrue(bst.Remove(12));
            Assert.IsNull(bst.Root.Right);
            Assert.AreEqual(2, bst.Count);
        }
開發者ID:taoxiease,項目名稱:asegrp,代碼行數:8,代碼來源:BinarySearchTreeTest.cs

示例15: RemoveLeafValueLessThanParentTest

        public void RemoveLeafValueLessThanParentTest()
        {
            BinarySearchTree<int> bst = new BinarySearchTree<int> {10, 7, 12, 11};

            Assert.IsTrue(bst.Remove(7));
            Assert.IsNull(bst.Root.Left);
            Assert.AreEqual(3, bst.Count);
        }
開發者ID:taoxiease,項目名稱:asegrp,代碼行數:8,代碼來源:BinarySearchTreeTest.cs


注:本文中的BinarySearchTree.Remove方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。