C++中的queue自身是不支持clear操做的,可是双端队列deque是支持clear操做的。c++
直接用空的队列对象赋值code
queue<int> q1; // process // ... q1 = queue<int>();
遍历出队列对象
while (!Q.empty()) Q.pop();
使用swap,这种是最高效的,定义clear,保持STL容器的标准。队列
void clear(queue<int>& q) { queue<int> empty; swap(empty, q); }