C++的stack
容器適配器可以存儲(chǔ)自定義類型。要實(shí)現(xiàn)這一點(diǎn),您需要確保滿足以下條件:
<
運(yùn)算符,因?yàn)?code>stack默認(rèn)使用<
運(yùn)算符來(lái)比較元素并進(jìn)行排序。如果您希望使用其他比較方式,您需要提供自定義的比較函數(shù)或類。以下是一個(gè)簡(jiǎn)單的示例,展示了如何在stack
中存儲(chǔ)自定義類型:
#include <iostream>
#include <stack>
class MyType {
public:
int value;
MyType(int v) : value(v) {}
// 重載 '<' 運(yùn)算符
bool operator<(const MyType& other) const {
return value < other.value;
}
};
int main() {
std::stack<MyType> myStack;
myStack.push(MyType(3));
myStack.push(MyType(1));
myStack.push(MyType(4));
while (!myStack.empty()) {
MyType top = myStack.top();
myStack.pop();
std::cout << "Top value: " << top.value << std::endl;
}
return 0;
}
在這個(gè)示例中,我們定義了一個(gè)名為MyType
的自定義類型,并重載了<
運(yùn)算符。然后,我們創(chuàng)建了一個(gè)stack
對(duì)象來(lái)存儲(chǔ)MyType
對(duì)象,并執(zhí)行了一些基本操作。