// a _naive_ dstack implementation
#include <iostream>
#include "dstack1.h"
dstack::dstack( int size)
{
v = new double[capacity = size];
sp = 0;
}
void dstack::push( double d)
{
if ( ! is_full() )
v[sp++] = d;
}
double dstack::pop()
{
// better with exceptions...
return is_empty() ? 0.0 : v[--sp];
}
bool dstack::is_empty() const
{
return 0 == sp;
}
bool dstack::is_full() const
{
return capacity == sp;
}
std::ostream &operator<<( std::ostream &os, dstack ds)
{
os << "[ ";
for ( int i = 0; i < ds.sp-1; ++i )
os << ds.v[i] << ", ";
if ( ds.sp > 0 )
os << ds.v[ds.sp-1];
os << " ]";
return os;
}