Beispiel #1
0
 def test_merge_empty_heap_with_non_empty_heap(self):
     a = MinHeap()
     ls = [-3, 5, 7, 9, 1, 5, 2]
     b = MinHeap(ls)
     self.assertIsNone(a.merge(b))
     self.assertEqual(a.size, len(ls))
     self.assertEqual(b.size, len(ls))
Beispiel #2
0
 def test_remove_min_when_heap_has_random_size(self):
     size = randint(3, 100)
     a = [randint(-100, 100) for _ in range(size)]
     h = MinHeap(a)
     m = min(a)
     self.assertEqual(h.remove_min(), m)
     self.assertFalse(h.is_empty())
     self.assertEqual(h.size, size - 1)
Beispiel #3
0
 def test_merge_non_empty_heap_with_non_empty_heap(self):
     ls = [-3, 5, 7, 9, 1, 5, 2]
     size = len(ls)
     a = MinHeap(ls)
     b = MinHeap(sample(ls, size))
     self.assertIsNone(a.merge(b))
     self.assertEqual(a.size, size * 2)
     self.assertEqual(b.size, size)
Beispiel #4
0
    def test_add_multiple_elements(self):
        a = [randint(-100, 100) for _ in range(100)]
        h = MinHeap()

        for i, elem in enumerate(a):
            self.assertIsNone(h.add(elem))
            self.assertEqual(h.size, i + 1)

        self.assertFalse(h.is_empty())
        self.assertEqual(h.find_min(), min(a))
Beispiel #5
0
    def test_delete_all_when_heap_of_random_size(self):
        size = randint(3, 100)
        a = [randint(-100, 100) for _ in range(size)]
        h = MinHeap(a)

        for _ in range(size):
            self.assertIsNone(h.delete(choice(a)))
            self.assertTrue(is_min_heap(h))

        self.assertEqual(h.size, 0)
        self.assertTrue(h.is_empty())
Beispiel #6
0
 def test_merge_non_empty_heap_with_empty_heap(self):
     ls = [-3, 5, 7, 9, 1, 5, 2]
     a = MinHeap(ls)
     b = MinHeap()
     self.assertIsNone(a.merge(b))
     self.assertEqual(a.size, len(ls))
     self.assertEqual(b.size, 0)
     self.assertTrue(b.is_empty())
Beispiel #7
0
 def test_contains_when_empty_heap(self):
     h = MinHeap()
     self.assertFalse(h.contains(3))
Beispiel #8
0
 def test_contains_when_argument_is_None(self):
     h = MinHeap()
     self.assertRaises(ValueError, h.contains, None)
Beispiel #9
0
 def test_find_min_when_heap_has_size_2(self):
     h = MinHeap([13, 7])
     self.assertEqual(h.find_min(), 7)
Beispiel #10
0
 def test_add_add_one(self):
     h = MinHeap()
     self.assertIsNone(h.add(2))
     self.assertEqual(h.size, 1)
     self.assertFalse(h.is_empty())
     self.assertEqual(h.find_min(), 2)
Beispiel #11
0
 def test_add_when_argument_is_None(self):
     h = MinHeap()
     self.assertRaises(ValueError, h.add, None)
Beispiel #12
0
 def test_clear_heap_of_random_size(self):
     h = MinHeap([randint(-100, 100) for _ in range(100)])
     self.assertIsNone(h.clear())
     self.assertEqual(h.size, 0)
     self.assertTrue(h.is_empty())
Beispiel #13
0
 def test_remove_min_when_heap_has_size_2(self):
     h = MinHeap([11, 13])
     self.assertEqual(h.remove_min(), 11)
     self.assertFalse(h.is_empty())
     self.assertEqual(h.size, 1)
Beispiel #14
0
 def test_find_min_when_heap_has_size_1(self):
     h = MinHeap([5])
     self.assertEqual(h.find_min(), 5)
Beispiel #15
0
 def test_delete_when_elem_is_last(self):
     h = MinHeap([3, 4])
     self.assertIsNone(h.delete(4))
     self.assertTrue(is_min_heap(h))
     self.assertEqual(h.size, 1)
     self.assertFalse(h.is_empty())
Beispiel #16
0
 def test_delete_when_argument_is_None(self):
     self.assertRaises(ValueError, MinHeap().delete, None)
Beispiel #17
0
 def test_find_min_when_heap_has_random_size(self):
     a = [randint(-100, 100) for _ in range(3, 100)]
     h = MinHeap(a)
     self.assertEqual(h.find_min(), min(a))
Beispiel #18
0
 def test_merge_empty_heap_with_empty_heap(self):
     a = MinHeap()
     b = MinHeap()
     self.assertIsNone(a.merge(b))
Beispiel #19
0
 def test_remove_min_when_empty_heap(self):
     h = MinHeap()
     self.assertIsNone(h.remove_min())
Beispiel #20
0
 def test_contains_true(self):
     h = MinHeap([6, 8, 2, 2, 60, 7, 9])
     self.assertTrue(h.contains(2))
Beispiel #21
0
 def test_clear_empty_heap(self):
     h = MinHeap()
     self.assertIsNone(h.clear())
     self.assertEqual(h.size, 0)
     self.assertTrue(h.is_empty())
Beispiel #22
0
 def test_contains_false(self):
     h = MinHeap([6, 8, 2, 60, 7, 9, 3, 67])
     self.assertFalse(h.contains(10))
Beispiel #23
0
 def test_remove_min_when_heap_has_size_1(self):
     h = MinHeap([13])
     self.assertEqual(h.remove_min(), 13)
     self.assertTrue(h.is_empty())
     self.assertEqual(h.size, 0)
Beispiel #24
0
 def test_delete_when_elem_does_not_exist(self):
     self.assertRaises(LookupError, MinHeap().delete, 3)
Beispiel #25
0
 def test_heap_creation_default(self):
     h = MinHeap()
     self.assertTrue(h.is_empty())
     self.assertEqual(h.size, 0)
Beispiel #26
0
 def test_heap_creation_given_list(self):
     a = [12, 14, 28, 6, 7, 10, 18]
     h = MinHeap(a)
     self.assertFalse(h.is_empty())
     self.assertEqual(h.size, len(a))
Beispiel #27
0
 def test_find_min_when_empty_heap(self):
     h = MinHeap()
     self.assertIsNone(h.find_min())