stdcpp/tsrc/Stdcpp_test/stlport/auto/stlport_mkheap/src/mkheap1.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Fri, 16 Apr 2010 16:46:38 +0300
changeset 18 47c74d1534e1
parent 0 e4d67989cc36
child 44 97b0fb8a2cc2
child 45 4b03adbd26ca
permissions -rw-r--r--
Revision: 201011 Kit: 201015

/*
* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description: 
*
*/
 
// STLport regression testsuite component.
// To compile as a separate example, please #define MAIN.

#include <algorithm>
#include <iostream>
#include <functional>

#ifdef MAIN 
#define mkheap1_test main
#endif

#if !defined (STLPORT) || defined(__STL_USE_NAMESPACES)
using namespace std;
#endif
int mkheap1_test(int, char**)
{
  cout<<"Results of mkheap1_test:"<<endl;
int numbers[6] = { 5, 10, 4, 13, 11, 19 };
int array[6];
int failures = 0,a = 0;
  make_heap(numbers, numbers + 6, greater<int>());
  for(int i = 6; i >= 1; i--)
  {
    cout << numbers[0] << endl;
    array[a++] = numbers[0];
    pop_heap(numbers, numbers + i, greater<int>());
  }
   if(array[0] != 4)
  failures++;
  if(array[1] != 5)
  failures++;
  if(array[2] != 10)
  failures++;
  if(array[3] != 11)
  failures++;
  if(array[4] != 13)
  failures++;
  if(array[5] != 19)
  failures++;

  return failures;
}