Way*_*Hsu 5 c++ inheritance stack templates
我试图创建自己的类(NodeWithMin)作为C++中的堆栈元素,并创建一个继承它的新类(StackWithMin).我想我可以创建新的堆栈类,但是有一些问题初始化新类的新实例并使用它.有没有人对它有好主意?我在一个文件中写了所有类和main.谢谢.
#include <stack>
class NodeWithMin{
public:
int value;
int min;
NodeWithMin(int v, int min){
this->value = v;
this->min = min;
}
};
template<class NodeWithMin>
class StackWithMin : stack<NodeWithMin>{
public:
typedef stack<NodeWithMin> super;
void push(int value){
int newMin = min(value, this->min());
super::push(new NodeWithMin(value, newMin));
};
int min(){
if(this->isEmpty()){
return numeric_limits<int>::max();
}else{
super::peek().min;
}
};
};
int main(int argc, const char * argv[])
{
StackWithMin<class NodeWithMin>* ss;
ss = new StackWithMin<class NodeWithMin>();
}
Run Code Online (Sandbox Code Playgroud)
小智 2
首先,我删除了
using namespace std;
Run Code Online (Sandbox Code Playgroud)
所以我有资格std消除歧义。
我注意到的第一个问题是这一行:
int newMin = min(value, this->min());
Run Code Online (Sandbox Code Playgroud)
我的猜测是您正在尝试使用minfrom algorithm(因为stack不包含min函数):
#include <algorithm>
// snip
int newMin = std::min(value, this->min())
Run Code Online (Sandbox Code Playgroud)
第二个问题是你没有 的实例stack<NodeWithMin>,只有 typedef。因此你需要像这样使用它:
typedef std::stack<NodeWithMin> super;
super super_instance;
void push(int value){
int newMin = std::min(value, this->min());
// Why are you using new? It would make
// It more difficult to avoid memory leaks
super_instance.push({value, newMin});
};
Run Code Online (Sandbox Code Playgroud)
第三个问题是stack没有名为 的成员函数isEmpty,您的类也没有。stack也没有peek成员函数。
int min(){
if(super_instance.empty()){
return std::numeric_limits<int>::max();
}else{
return super_instance.top().min;
}
};
Run Code Online (Sandbox Code Playgroud)
现在它将编译:
int main(int argc, const char * argv[])
{
StackWithMin<class NodeWithMin>* ss;
ss = new StackWithMin<class NodeWithMin>();
ss->push(42);
delete ss;
}
Run Code Online (Sandbox Code Playgroud)
我没有费心检查逻辑错误。