Beispiel #1
0
        public void Test_contains()
        {
            var heapItems = new HeapItems();
            var heap      = new Heap <int>(16, heapItems);

            heap.Add(0);
            heap.Add(1);
            heap.Add(2);
            heap.Add(3);
            heap.Add(4);
            heap.Add(5);

            Assert.Equal(true, heap.Contains(0));
            Assert.Equal(true, heap.Contains(5));
            Assert.Equal(false, heap.Contains(6));
        }
Beispiel #2
0
        public void Test_remove_first()
        {
            var heapItems = new HeapItems();
            var heap      = new Heap <int>(16, heapItems);

            heap.Add(5);
            heap.Add(4);
            heap.Add(3);
            heap.Add(2);
            heap.Add(1);
            heap.Add(0);

            Assert.Equal(0, heap.RemoveFirst());
            Assert.Equal(1, heap.RemoveFirst());
            Assert.Equal(2, heap.RemoveFirst());
            Assert.Equal(3, heap.RemoveFirst());
            Assert.Equal(4, heap.RemoveFirst());
            Assert.Equal(5, heap.RemoveFirst());
        }
Beispiel #3
0
        public void Add_with_always_a_sorting_to_the_top()
        {
            var heapItems = new HeapItems();
            var heap      = new Heap <int>(16, heapItems);

            heap.Add(5);
            heap.Add(4);
            heap.Add(3);
            heap.Add(2);
            heap.Add(1);
            heap.Add(0);

            var items = (int[])typeof(Heap <int>).GetField("items", BindingFlags.NonPublic | BindingFlags.Instance).GetValue(heap);

            Assert.Equal(0, items[0]);
            Assert.Equal(2, items[1]);
            Assert.Equal(1, items[2]);
            Assert.Equal(5, items[3]);
            Assert.Equal(3, items[4]);
            Assert.Equal(4, items[5]);
        }
Beispiel #4
0
        public void Test_update_item()
        {
            var heapItems = new HeapItems();
            var heap      = new Heap <int>(16, heapItems);

            heap.Add(5);
            heap.Add(4);
            heap.Add(3);
            heap.Add(2);
            heap.Add(1);
            heap.Add(0);

            heapItems.SetItem(1, 100);
            heap.UpdateItem(1);

            var items = (int[])typeof(Heap <int>).GetField("items", BindingFlags.NonPublic | BindingFlags.Instance).GetValue(heap);

            Assert.Equal(1, items[0]);
            Assert.Equal(2, items[1]);
            Assert.Equal(0, items[2]);
            Assert.Equal(5, items[3]);
            Assert.Equal(3, items[4]);
            Assert.Equal(4, items[5]);
        }