83 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
/*****************************************************************************************[Queue.h]
 | 
						|
MiniSat -- Copyright (c) 2003-2006, Niklas Een, Niklas Sorensson
 | 
						|
 | 
						|
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and
 | 
						|
associated documentation files (the "Software"), to deal in the Software without restriction,
 | 
						|
including without limitation the rights to use, copy, modify, merge, publish, distribute,
 | 
						|
sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
 | 
						|
furnished to do so, subject to the following conditions:
 | 
						|
 | 
						|
The above copyright notice and this permission notice shall be included in all copies or
 | 
						|
substantial portions of the Software.
 | 
						|
 | 
						|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT
 | 
						|
NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
 | 
						|
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
 | 
						|
DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT
 | 
						|
OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
 | 
						|
**************************************************************************************************/
 | 
						|
 | 
						|
#ifndef Queue_h
 | 
						|
#define Queue_h
 | 
						|
 | 
						|
#include "Vec.h"
 | 
						|
 | 
						|
//=================================================================================================
 | 
						|
 | 
						|
 | 
						|
template <class T>
 | 
						|
class Queue {
 | 
						|
    vec<T>  elems;
 | 
						|
    int     first;
 | 
						|
 | 
						|
public:
 | 
						|
    Queue(void) : first(0) { }
 | 
						|
 | 
						|
    void insert(T x)   { elems.push(x); }
 | 
						|
    T    peek  () const { return elems[first]; }
 | 
						|
    void pop   () { first++; }
 | 
						|
 | 
						|
    void clear(bool dealloc = false)   { elems.clear(dealloc); first = 0; }
 | 
						|
    int  size(void)    { return elems.size() - first; }
 | 
						|
 | 
						|
    //bool has(T x) { for (int i = first; i < elems.size(); i++) if (elems[i] == x) return true; return false; }
 | 
						|
 | 
						|
    const T& operator [] (int index) const  { return elems[first + index]; }
 | 
						|
 | 
						|
};
 | 
						|
 | 
						|
//template<class T>
 | 
						|
//class Queue {
 | 
						|
//    vec<T>  buf;
 | 
						|
//    int     first;
 | 
						|
//    int     end;
 | 
						|
//
 | 
						|
//public:
 | 
						|
//    typedef T Key;
 | 
						|
//
 | 
						|
//    Queue() : buf(1), first(0), end(0) {}
 | 
						|
//
 | 
						|
//    void clear () { buf.shrinkTo(1); first = end = 0; }
 | 
						|
//    int  size  () { return (end >= first) ? end - first : end - first + buf.size(); }
 | 
						|
//
 | 
						|
//    T    peek  () { assert(first != end); return buf[first]; }
 | 
						|
//    void pop   () { assert(first != end); first++; if (first == buf.size()) first = 0; }
 | 
						|
//    void insert(T elem) {   // INVARIANT: buf[end] is always unused
 | 
						|
//        buf[end++] = elem;
 | 
						|
//        if (end == buf.size()) end = 0;
 | 
						|
//        if (first == end){  // Resize:
 | 
						|
//            vec<T>  tmp((buf.size()*3 + 1) >> 1);
 | 
						|
//            //**/printf("queue alloc: %d elems (%.1f MB)\n", tmp.size(), tmp.size() * sizeof(T) / 1000000.0);
 | 
						|
//            int     i = 0;
 | 
						|
//            for (int j = first; j < buf.size(); j++) tmp[i++] = buf[j];
 | 
						|
//            for (int j = 0    ; j < end       ; j++) tmp[i++] = buf[j];
 | 
						|
//            first = 0;
 | 
						|
//            end   = buf.size();
 | 
						|
//            tmp.moveTo(buf);
 | 
						|
//        }
 | 
						|
//    }
 | 
						|
//};
 | 
						|
 | 
						|
//=================================================================================================
 | 
						|
#endif
 |