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
 |