SNAP Library , User Reference  2013-01-07 14:03:36
SNAP, a general purpose, high performance system for analysis and manipulation of large networks
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Defines
TQQueue< TVal > Class Template Reference

#include <ds.h>

List of all members.

Public Member Functions

 TQQueue (const int &_MxLast=64, const int &_MxLen=-1)
 TQQueue (const TQQueue &Queue)
 TQQueue (TSIn &SIn)
void Save (TSOut &SOut) const
TQQueueoperator= (const TQQueue &Queue)
const TVal & operator[] (const int &ValN) const
void Clr (const bool &DoDel=true)
void Gen (const int &_MxLast=64, const int &_MxLen=-1)
void GetSubValV (const int &_BValN, const int &_EValN, TVec< TVal > &SubValV) const
bool Empty () const
int Len () const
const TVal & Top () const
void Pop ()
void Push (const TVal &Val)
void Shuffle (TRnd &Rnd)

Private Attributes

TInt MxLast
TInt MxLen
TInt First
TInt Last
TVec< TVal > ValV

Detailed Description

template<class TVal>
class TQQueue< TVal >

Definition at line 2108 of file ds.h.


Constructor & Destructor Documentation

template<class TVal>
TQQueue< TVal >::TQQueue ( const int &  _MxLast = 64,
const int &  _MxLen = -1 
) [inline]

Definition at line 2114 of file ds.h.

                                                      :
    MxLast(_MxLast), MxLen(_MxLen), First(0), Last(0), ValV(){
    Assert(int(MxLast)>0); Assert((MxLen==-1)||(int(MxLen)>0));}
template<class TVal>
TQQueue< TVal >::TQQueue ( const TQQueue< TVal > &  Queue) [inline]

Definition at line 2117 of file ds.h.

                               :
    MxLast(Queue.MxLast), MxLen(Queue.MxLen),
    First(Queue.First), Last(Queue.Last), ValV(Queue.ValV){}
template<class TVal>
TQQueue< TVal >::TQQueue ( TSIn SIn) [inline, explicit]

Definition at line 2120 of file ds.h.

                             :
    MxLast(SIn), MxLen(SIn), First(SIn), Last(SIn), ValV(SIn){}

Member Function Documentation

template<class TVal>
void TQQueue< TVal >::Clr ( const bool &  DoDel = true) [inline]

Definition at line 2133 of file ds.h.

{ValV.Clr(DoDel); First=Last=0;}
template<class TVal>
bool TQQueue< TVal >::Empty ( ) const [inline]

Definition at line 2144 of file ds.h.

{return First==Last;}
template<class TVal>
void TQQueue< TVal >::Gen ( const int &  _MxLast = 64,
const int &  _MxLen = -1 
) [inline]

Definition at line 2134 of file ds.h.

                                                       {
    MxLast=_MxLast; MxLen=_MxLen; First=0; Last=0; ValV.Clr();}
template<class TVal>
void TQQueue< TVal >::GetSubValV ( const int &  _BValN,
const int &  _EValN,
TVec< TVal > &  SubValV 
) const [inline]

Definition at line 2136 of file ds.h.

                                                                                   {
    int BValN=TInt::GetMx(0, _BValN);
    int EValN=TInt::GetMn(Len()-1, _EValN);
    SubValV.Gen(EValN-BValN+1);
    for (int ValN=BValN; ValN<=EValN; ValN++){
      SubValV[ValN-BValN]=ValV[Last+ValN];}
  }
template<class TVal>
int TQQueue< TVal >::Len ( ) const [inline]

Definition at line 2145 of file ds.h.

{return First-Last;}
template<class TVal>
TQQueue& TQQueue< TVal >::operator= ( const TQQueue< TVal > &  Queue) [inline]

Definition at line 2126 of file ds.h.

                                          {
    if (this!=&Queue){MxLast=Queue.MxLast; MxLen=Queue.MxLen;
      First=Queue.First; Last=Queue.Last; ValV=Queue.ValV;}
    return *this;}
template<class TVal>
const TVal& TQQueue< TVal >::operator[] ( const int &  ValN) const [inline]

Definition at line 2130 of file ds.h.

                                                {Assert((0<=ValN)&&(ValN<Len()));
    return ValV[Last+ValN];}
template<class TVal>
void TQQueue< TVal >::Pop ( ) [inline]

Definition at line 2148 of file ds.h.

            {
    IAssert(First!=Last); Last++;
    if (First==Last){ValV.Clr(); First=Last=0;}}
template<class TVal>
void TQQueue< TVal >::Push ( const TVal &  Val) [inline]

Definition at line 2151 of file ds.h.

                            {
    if (Last>MxLast){ValV.Del(0, Last-1); First-=Last; Last=0;}
    if ((MxLen!=-1)&&(MxLen==Len())){Pop();}
    First++; ValV.Add(Val);}
template<class TVal>
void TQQueue< TVal >::Save ( TSOut SOut) const [inline]

Definition at line 2122 of file ds.h.

                               {
    MxLast.Save(SOut); MxLen.Save(SOut);
    First.Save(SOut); Last.Save(SOut); ValV.Save(SOut);}
template<class TVal>
void TQQueue< TVal >::Shuffle ( TRnd Rnd) [inline]

Definition at line 2156 of file ds.h.

                         {
    TVec<TVal> ValV(Len(), 0); while (!Empty()){ValV.Add(Top()); Pop();}
    ValV.Shuffle(Rnd); Clr();
    for (int ValN=0; ValN<ValV.Len(); ValN++){Push(ValV[ValN]);}}
template<class TVal>
const TVal& TQQueue< TVal >::Top ( ) const [inline]

Definition at line 2146 of file ds.h.

                          {
    Assert(First!=Last); return ValV[Last];}

Member Data Documentation

template<class TVal>
TInt TQQueue< TVal >::First [private]

Definition at line 2111 of file ds.h.

template<class TVal>
TInt TQQueue< TVal >::Last [private]

Definition at line 2111 of file ds.h.

template<class TVal>
TInt TQQueue< TVal >::MxLast [private]

Definition at line 2110 of file ds.h.

template<class TVal>
TInt TQQueue< TVal >::MxLen [private]

Definition at line 2110 of file ds.h.

template<class TVal>
TVec<TVal> TQQueue< TVal >::ValV [private]

Definition at line 2112 of file ds.h.


The documentation for this class was generated from the following file: