之前我写过一篇c++的模板函数,这篇博客使用模板函数和模板类实现一下简易化的栈
模板函数的博客地址
和定义函数模板一样,我们可以定义类模板,泛型类声明的一般形式如下:
template <class type> class class-name {
.
.
.
}
然后我们简单实现一下栈
#include <iostream>
#include<vector>
#include<algorithm>
#include<deque>
using namespace std;
template <class T>
class Stack {
vector<T> elems;
public :
void push(T const&);
void pop();
T top() const;
bool empty() const {
return elems.empty();
}
int size() const {
return elems.size();
}
int& operator[](int i)
{
if (i > elems.size())
{
cout << "索引超过最大值" << endl;
// 返回第一个元素
return elems[0];
}
return elems[i];
}
};
template <class T>
void Stack<T>::push(T const& elem) {
elems.push_back(elem);
}
template <class T>
T Stack<T>::top() const
{
if (elems.empty()) {
cout << "栈为空!" << endl;
}
// 返回最后一个元素的副本
return elems.back();
}
template <class T>
void Stack<T>::pop() {
if (elems.empty()) {
cout << "栈为空!" << endl;
}
elems.pop_back();
}
int main() {
Stack<int> stack;
stack.push(100);
stack.push(120);
cout << "索引输出:";
cout << stack[0] << endl;
cout << "遍历输出:"<<endl;
while (stack.size() > 0) {
cout << stack.top() << endl;
stack.pop();
}
return 0;
}
然后我们运行可以输出我们想要输出的元素
就是上边这些 c++模板类就介绍完成了,
我们可能会发现c++的功能是真的太强大了
希望我所写的对大家有所帮助