在c++中实现setOfStacks
Implementing a setOfStacks in c++
我正在尝试实现一组堆栈,在c++中使用向量。因此,我首先声明std::stack类型的std::vector,然后在vector中的堆栈上执行常规的push和pop操作。堆栈有一个阈值。如果向量中的堆栈已达到阈值,则向向量添加一个新堆栈。实现如下-
#define threshold 3
class setOfStacks{
std::vector<std::stack<int> > *stacks;
public:
setOfStacks(){
stacks = new std::vector<std::stack<int> >();
};
~setOfStacks(){};
void push(int d){
if(stacks->size()==0){
std::stack<int> newStack;
newStack.push(d);
stacks->push_back(newStack);
}
else{
std::stack<int> s = stacks->back();
std::cout<<s.size()<<"n";
if(s.size()!=threshold){
s.push(d);
}
else{
std::stack<int> newStack;
newStack.push(d);
stacks->push_back(newStack);
}
std::cout<<s.size()<<"n";
}
}
void pop(){
if(stacks->size()==0){
std::cout<<"No elements in the stackn";
}
else{
std::stack<int> s;
s = stacks->back();
if(!s.empty()){
std::cout<<s.top()<<" is being removedn";
s.pop();
}
else{
stacks->pop_back();
pop();
}
}
}
};
int main(){
setOfStacks stackSet;
stackSet.push(1);
stackSet.push(2);
stackSet.push(3);
stackSet.push(4);
stackSet.push(5);
stackSet.push(6);
stackSet.push(7);
stackSet.push(8);
stackSet.push(9);
stackSet.pop();
stackSet.pop();
stackSet.pop();
stackSet.pop();
return 0;
}
我面临的问题- 1被插入到第一个堆栈中,堆栈被插入到向量中。当我尝试插入2时,从向量返回的堆栈引用包含1,其大小低于阈值,即3,因此2被推入堆栈。但是当我尝试插入3时,由向量返回的堆栈引用在其中没有2,它再次只包含1。我不明白为什么会这样。有人能帮我一下吗?
这一行:
std::stack<int> s = stacks->back();
从stacks
获取stack<int>
的拷贝。然后,当你按压它时,你只是按压了副本。
将其更改为引用:
std::stack<int> &s = stacks->back();
那么当您使用引用进行更改时,更改将反映在堆栈向量中。
相关文章:
- 如果没有malloc,链表实现将失败
- 如何在c++中实现处理器调度模拟器
- 如何在c++中使用引用实现类似python的行为
- 实现无开销push_back的最佳方法是什么
- 使用简单类型列表实现的指数编译时间.为什么
- 如何在BST的这个简单递归实现中消除警告
- 实现一个在集合上迭代的模板函数
- 我应该实现右值推送功能吗?我应该使用std::move吗
- 如何正确实现和访问运算符的各种自定义枚举器
- C++Union/Struct位域的实现和可移植性
- 这个极客对极客的trie实现是否存在内存泄漏问题
- 在c++中实现LinkedList时,应出现未处理的错误
- 为左值和右值的包装器实现C++范围
- 使用模板进行堆栈实现; "name followed by :: must be a class or namespace"
- 使用GSoap实现ONVIF
- 在用于格式4的arm模拟器中实现功能时的一个问题
- 用于AVX的ln(x)的实现,m256
- 用常见虚拟函数实现的任意组合来实现派生类的正确方法是什么
- 在C++中,如何在类和函数(可能是模板化的)的头中编写完整的实现
- 在c++中实现setOfStacks