os/ossrv/genericopenlibs/cppstdlib/stl/test/unit/heap_test.cpp
author sl@SLION-WIN7.fritz.box
Fri, 15 Jun 2012 03:10:57 +0200
changeset 0 bde4ae8d615e
permissions -rw-r--r--
First public contribution.
sl@0
     1
#include <vector>
sl@0
     2
#include <algorithm>
sl@0
     3
#include <functional>
sl@0
     4
sl@0
     5
#include "cppunit/cppunit_proxy.h"
sl@0
     6
sl@0
     7
#if !defined (STLPORT) || defined(_STLP_USE_NAMESPACES)
sl@0
     8
using namespace std;
sl@0
     9
#endif
sl@0
    10
sl@0
    11
//
sl@0
    12
// TestCase class
sl@0
    13
//
sl@0
    14
class HeapTest : public CPPUNIT_NS::TestCase
sl@0
    15
{
sl@0
    16
  CPPUNIT_TEST_SUITE(HeapTest);
sl@0
    17
  CPPUNIT_TEST(mkheap0);
sl@0
    18
  CPPUNIT_TEST(mkheap1);
sl@0
    19
  CPPUNIT_TEST(pheap1);
sl@0
    20
  CPPUNIT_TEST(pheap2);
sl@0
    21
  CPPUNIT_TEST_SUITE_END();
sl@0
    22
sl@0
    23
protected:
sl@0
    24
  void mkheap0();
sl@0
    25
  void mkheap1();
sl@0
    26
  void pheap1();
sl@0
    27
  void pheap2();
sl@0
    28
};
sl@0
    29
sl@0
    30
CPPUNIT_TEST_SUITE_REGISTRATION(HeapTest);
sl@0
    31
sl@0
    32
//
sl@0
    33
// tests implementation
sl@0
    34
//
sl@0
    35
void HeapTest::mkheap0()
sl@0
    36
{
sl@0
    37
  int numbers[6] = { 5, 10, 4, 13, 11, 19 };
sl@0
    38
sl@0
    39
  make_heap(numbers, numbers + 6);
sl@0
    40
  CPPUNIT_ASSERT(numbers[0]==19)
sl@0
    41
  pop_heap(numbers, numbers + 6);
sl@0
    42
  CPPUNIT_ASSERT(numbers[0]==13)
sl@0
    43
  pop_heap(numbers, numbers + 5);
sl@0
    44
  CPPUNIT_ASSERT(numbers[0]==11)
sl@0
    45
  pop_heap(numbers, numbers + 4);
sl@0
    46
  CPPUNIT_ASSERT(numbers[0]==10)
sl@0
    47
  pop_heap(numbers, numbers + 3);
sl@0
    48
  CPPUNIT_ASSERT(numbers[0]==5)
sl@0
    49
  pop_heap(numbers, numbers + 2);
sl@0
    50
  CPPUNIT_ASSERT(numbers[0]==4)
sl@0
    51
  pop_heap(numbers, numbers + 1);
sl@0
    52
}
sl@0
    53
void HeapTest::mkheap1()
sl@0
    54
{
sl@0
    55
  int numbers[6] = { 5, 10, 4, 13, 11, 19 };
sl@0
    56
sl@0
    57
  make_heap(numbers, numbers + 6, greater<int>());
sl@0
    58
sl@0
    59
  CPPUNIT_ASSERT(numbers[0]==4)
sl@0
    60
  pop_heap(numbers, numbers + 6, greater<int>());
sl@0
    61
  CPPUNIT_ASSERT(numbers[0]==5)
sl@0
    62
  pop_heap(numbers, numbers + 5, greater<int>());
sl@0
    63
  CPPUNIT_ASSERT(numbers[0]==10)
sl@0
    64
  pop_heap(numbers, numbers + 4, greater<int>());
sl@0
    65
  CPPUNIT_ASSERT(numbers[0]==11)
sl@0
    66
  pop_heap(numbers, numbers + 3, greater<int>());
sl@0
    67
  CPPUNIT_ASSERT(numbers[0]==13)
sl@0
    68
  pop_heap(numbers, numbers + 2, greater<int>());
sl@0
    69
  CPPUNIT_ASSERT(numbers[0]==19)
sl@0
    70
}
sl@0
    71
void HeapTest::pheap1()
sl@0
    72
{
sl@0
    73
  vector<int> v;
sl@0
    74
sl@0
    75
  v.push_back(1);
sl@0
    76
  v.push_back(20);
sl@0
    77
  v.push_back(4);
sl@0
    78
  make_heap(v.begin(), v.end());
sl@0
    79
sl@0
    80
  v.push_back(7);
sl@0
    81
  push_heap(v.begin(), v.end());
sl@0
    82
sl@0
    83
  sort_heap(v.begin(), v.end());
sl@0
    84
sl@0
    85
  CPPUNIT_ASSERT(v[0]==1);
sl@0
    86
  CPPUNIT_ASSERT(v[1]==4);
sl@0
    87
  CPPUNIT_ASSERT(v[2]==7);
sl@0
    88
  CPPUNIT_ASSERT(v[3]==20);
sl@0
    89
}
sl@0
    90
void HeapTest::pheap2()
sl@0
    91
{
sl@0
    92
  vector<int> v;
sl@0
    93
sl@0
    94
  v.push_back(1);
sl@0
    95
  v.push_back(20);
sl@0
    96
  v.push_back(4);
sl@0
    97
  make_heap(v.begin(), v.end(), greater<int>());
sl@0
    98
sl@0
    99
  v.push_back(7);
sl@0
   100
  push_heap(v.begin(), v.end(), greater<int>());
sl@0
   101
sl@0
   102
  sort_heap(v.begin(), v.end(), greater<int>());
sl@0
   103
sl@0
   104
  CPPUNIT_ASSERT(v[0]==20);
sl@0
   105
  CPPUNIT_ASSERT(v[1]==7);
sl@0
   106
  CPPUNIT_ASSERT(v[2]==4);
sl@0
   107
  CPPUNIT_ASSERT(v[3]==1);
sl@0
   108
}