tests/testthat/test_heaps.R

context("Heaps")

test_heap <- function(empty) {
  heap <- empty
  expect_true(is_empty(heap))

  heap <- insert(heap, 3)
  expect_false(is_empty(heap))
  expect_equal(find_minimal(heap), 3)

  heap <- insert(heap, 5)
  expect_equal(find_minimal(heap), 3)

  heap <- insert(heap, 2)
  expect_equal(find_minimal(heap), 2)

  heap <- insert(heap, 1)
  expect_equal(find_minimal(heap), 1)

  heap <- delete_minimal(heap)
  expect_equal(find_minimal(heap), 2)

  heap <- delete_minimal(heap)
  expect_equal(find_minimal(heap), 3)

  heap <- delete_minimal(heap)
  expect_equal(find_minimal(heap), 5)

  heap <- delete_minimal(heap)
  expect_true(is_empty(heap))


  for (x in sample(1:100))
    heap <- insert(heap, x)
  expect_equal(size(heap), 100)
  v <- vector("numeric", length = 100)
  for (i in 1:100) {
    v[i] <- find_minimal(heap)
    heap <- delete_minimal(heap)
  }
  expect_true(is_empty(heap))
  expect_equal(v, 1:100)
}

test_mixing_operations <- function(empty) {
  heap <- empty
  for (i in 1:10) heap <- insert(heap, i)
  for (i in 1:5) heap <- delete_minimal(heap)
  for (i in 11:15) heap <- insert(heap, i)

  v <- vector("numeric", length = 10)
  for (i in 1:10) {
    v[i] <- find_minimal(heap)
    heap <- delete_minimal(heap)
  }

  expect_true(is_empty(heap))
  expect_equal(v, 6:15)
}

test_merging <- function(empty) {
  h1 <- vector_to_heap(1:6, empty)
  h2 <- vector_to_heap(rev(7:12), empty)
  h3 <- vector_to_heap(sample(13:18), empty)
  heap <- merge(merge(h1, h2), h3)

  v <- vector("numeric", length = 18)
  for (i in 1:18) {
    v[i] <- find_minimal(heap)
    heap <- delete_minimal(heap)
  }
  expect_true(is_empty(heap))
  expect_equal(v, 1:18)

}


test_that("We can construct and access a leftist heap", {
  test_heap(empty_leftist_heap())
  test_mixing_operations(empty_leftist_heap())
  test_merging(empty_leftist_heap())
})

test_that("We can construct and access a binomial heap", {
  test_heap(empty_binomial_heap())
  test_mixing_operations(empty_binomial_heap())
  test_merging(empty_binomial_heap())
})

test_that("We can construct and access a splay heap", {
  test_heap(empty_splay_heap())
  test_mixing_operations(empty_splay_heap())
  test_merging(empty_splay_heap())
})
mailund/ralgo documentation built on May 21, 2019, 11:07 a.m.