IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> C++实现顺序栈(函数类外实现&&模板) -> 正文阅读

[JavaScript知识库]C++实现顺序栈(函数类外实现&&模板)

1.类

const int MAX_SIZE = 100;
template <class DataType>
class stack
{
private:
	DataType* data;//属性:线性表!
	int size;//堆栈实际大小
	int top;//栈顶
	//函数类外表示
public:
	stack();//默认构造函数
	
	stack(int s);//有参构造函数
	
	~stack();//析构函数
	
	void push(DataType ch);//入栈
	
	DataType pop();//出栈并返回栈顶元素
	
	DataType getTop();//获得栈顶元素但不出栈
	
	bool isEmpty();//判断栈是否为空
	
	bool isFull();//判断栈是否满
	
	void setNull();//设置栈为空!!!!

	//捕捉异常需要设定内部类!!!!!
	class Full {};
	class Empty {};//注意是花括号!!!
};

2.类外实现函数接口

1.无参构造函数

//无参构造函数
stack<DataType>::stack() 
{
	size = MAX_SIZE;
	top = -1;
	data = new DataType[MAX_SIZE];
}

2.有参构造函数

//有参构造函数
template <class DataType>
stack<DataType>::stack(int s) {
	size = s;
	top = -1;
	data = new DataType[size];
}

3.//析构函数,释放堆区数据

//析构函数,释放堆区数据
template <class DataType>
stack<DataType>::~stack()
{
	delete []data;//内存回收 释放new创建data占用的内存

	cout << "析构函数finished delete\n";
}

4.//入栈操作

//入栈操作
template <class DataType>
void stack<DataType>::push(DataType ch) {
	if (isFull())
		throw stack<DataType>::Full();//若栈已满,再进行入栈操作,则抛出异常
	else
		data[++top] = ch;
	//return true;
}

5.//出栈操作

//出栈操作
template <class DataType>
DataType stack<DataType>::pop() {
	if (isEmpty())
		throw stack<DataType>::Empty();//若栈为空,再进行出栈操作,则抛出异常
	else
		return data[top--];
}

6.//得到栈顶元素

//得到栈顶元素
template <class DataType>
DataType stack<DataType>::getTop() 
{
	if (!isEmpty())
		return data[top];
}

7.//判断栈是否为空

//判断栈是否为空
template <class DataType>
bool stack<DataType>::isEmpty() 
{
	if (top == -1) {
		return true;
	}
	else {
		return false;
	}
}

8.//判断栈是否满了

//判断栈是否满了
template <class DataType>
bool stack<DataType>::isFull() {
	if (top == size - 1) {
		return true;
	}
	else {
		return false;
	}
}

9.//设置栈为空!!!!

//设置栈为空!!!!
template <class DataType>
void stack<DataType>::setNull() {
	top = -1;
	cout << "top=-1!\n";
}

3.stack.cpp

#include "stack.hpp"
#include <iostream>
using namespace std;

int main() {
	stack<char> st(2);
	//stack<char> st(2);//利用两者均可构造函数初始化
	char ch;
	try {
		st.push('a');
		st.push('b');
		st.push('c');
	}
	catch (stack<char>::Full) {//注意!!!此处FULL后面不需要括号!!!!!
		cout << "stack full!\n";
	}
	try {
		ch = st.pop();
		cout << ch << endl;
		ch = st.pop();
		cout << ch << endl;
		ch = st.pop();
		cout << ch << endl;
	}
	catch (stack<char>::Empty) //若栈为空,再进行出栈操作,则抛出异常
	{
		cout << "stack empty!\n";
	}

	double c;
	stack<double> sl(2);
	try {
		sl.push(1998.3);
		sl.push(1999.9);
		sl.push(2000.1);
	}
	catch (stack<double>::Full) {//注意!!!此处FULL后面不需要括号!!!!!
		cout << "stack full!\n";
	}
	try {
		c = sl.pop();
		cout << c << endl;
		c = sl.pop();
		cout << c << endl;
		c = sl.pop();
		cout << c << endl;
	}
	catch (stack<double>::Empty) {
		cout << "stack empty!\n";
	}
	return 0;
}

4.总源码(分文件)

1.stack.hpp

#pragma once
const int MAX_SIZE = 100;
template <class DataType>
class stack
{
private:
	DataType* data;//属性:线性表!
	int size;//堆栈实际大小
	int top;//栈顶
	//函数类外表示
public:
	stack();//默认构造函数
	stack(int s);//有参构造函数
	~stack();//析构函数
	void push(DataType ch);//入栈
	DataType pop();//出栈并返回栈顶元素
	DataType getTop();//获得栈顶元素但不出栈
	bool isEmpty();//判断栈是否为空
	bool isFull();//判断栈是否满
	void setNull();//设置栈为空!!!!

	//捕捉异常需要设定内部类!!!!!
	class Full {};
	class Empty {};//注意是花括号!!!
};
//#endif
#include <iostream>
using namespace std;
template <class DataType>
//无参构造函数
stack<DataType>::stack() 
{
	size = MAX_SIZE;
	top = -1;
	data = new DataType[MAX_SIZE];
}
//有参构造函数
template <class DataType>
stack<DataType>::stack(int s) {
	size = s;
	top = -1;
	data = new DataType[size];
}
//析构函数,释放堆区数据
template <class DataType>
stack<DataType>::~stack()
{
	delete []data;//内存回收 释放new创建data占用的内存

	cout << "析构函数finished delete\n";
}
//入栈操作
template <class DataType>
void stack<DataType>::push(DataType ch) {
	if (isFull())
		throw stack<DataType>::Full();//若栈已满,再进行入栈操作,则抛出异常
	else
		data[++top] = ch;
	//return true;
}
//出栈操作
template <class DataType>
DataType stack<DataType>::pop() {
	if (isEmpty())
		throw stack<DataType>::Empty();//若栈为空,再进行出栈操作,则抛出异常
	else
		return data[top--];
}
//得到栈顶元素
template <class DataType>
DataType stack<DataType>::getTop() 
{
	if (!isEmpty())
		return data[top];
}
//判断栈是否为空
template <class DataType>
bool stack<DataType>::isEmpty() 
{
	if (top == -1) {
		return true;
	}
	else {
		return false;
	}
}
//判断栈是否满了
template <class DataType>
bool stack<DataType>::isFull() {
	if (top == size - 1) {
		return true;
	}
	else {
		return false;
	}
}
//设置栈为空!!!!
template <class DataType>
void stack<DataType>::setNull() {
	top = -1;
	cout << "top=-1!\n";
}

2.stack.cpp

#include "stack.hpp"
#include <iostream>
using namespace std;

int main() {
	stack<char> st(2);
	//stack<char> st(2);//利用两者均可构造函数初始化
	char ch;
	try {
		st.push('m');
		st.push('k');
		st.push('v');
	}
	catch (stack<char>::Full) {//注意!!!此处FULL后面不需要括号!!!!!
		cout << "stack full!\n";
	}
	try {
		ch = st.pop();
		cout << ch << endl;
		ch = st.pop();
		cout << ch << endl;
		ch = st.pop();
		cout << ch << endl;
	}
	catch (stack<char>::Empty) //若栈为空,再进行出栈操作,则抛出异常
	{
		cout << "stack empty!\n";
	}

	double c;
	stack<double> sl(2);
	try {
		sl.push(6165.2);
		sl.push(65.2);
		sl.push(12.888);
	}
	catch (stack<double>::Full) {//注意!!!此处FULL后面不需要括号!!!!!
		cout << "stack full!\n";
	}
	try {
		c = sl.pop();
		cout << c << endl;
		c = sl.pop();
		cout << c << endl;
		c = sl.pop();
		cout << c << endl;
	}
	catch (stack<double>::Empty) {
		cout << "stack empty!\n";
	}
	return 0;
}

5,总源码(单文件)

#include <iostream>
using namespace std;
const int MAX_SIZE = 100;
template <class DataType>
class stack
{
private:
	DataType* data;//属性:线性表!
	int size;//堆栈实际大小
	int top;//栈顶
	//函数类外表示
public:
	stack();//默认构造函数
	stack(int s);//有参构造函数
	~stack();//析构函数
	void push(DataType ch);//入栈
	DataType pop();//出栈并返回栈顶元素
	DataType getTop();//获得栈顶元素但不出栈
	bool isEmpty();//判断栈是否为空
	bool isFull();//判断栈是否满
	void setNull();//设置栈为空!!!!

	//捕捉异常需要设定内部类!!!!!
	class Full {};
	class Empty {};//注意是花括号!!!
};
template <class DataType>
//无参构造函数
stack<DataType>::stack()
{
	size = MAX_SIZE;
	top = -1;
	data = new DataType[MAX_SIZE];
}
//有参构造函数
template <class DataType>
stack<DataType>::stack(int s) {
	size = s;
	top = -1;
	data = new DataType[size];
}
//析构函数,释放堆区数据
template <class DataType>
stack<DataType>::~stack()
{
	delete[]data;//内存回收 释放new创建data占用的内存

	cout << "析构函数finished delete\n";
}
//入栈操作
template <class DataType>
void stack<DataType>::push(DataType ch) {
	if (isFull())
		throw stack<DataType>::Full();//若栈已满,再进行入栈操作,则抛出异常
	else
		data[++top] = ch;
	//return true;
}
//出栈操作
template <class DataType>
DataType stack<DataType>::pop() {
	if (isEmpty())
		throw stack<DataType>::Empty();//若栈为空,再进行出栈操作,则抛出异常
	else
		return data[top--];
}
//得到栈顶元素
template <class DataType>
DataType stack<DataType>::getTop()
{
	if (!isEmpty())
		return data[top];
}
//判断栈是否为空
template <class DataType>
bool stack<DataType>::isEmpty()
{
	if (top == -1) {
		return true;
	}
	else {
		return false;
	}
}
//判断栈是否满了
template <class DataType>
bool stack<DataType>::isFull() {
	if (top == size - 1) {
		return true;
	}
	else {
		return false;
	}
}
//设置栈为空!!!!
template <class DataType>
void stack<DataType>::setNull() {
	top = -1;
	cout << "top=-1!\n";
}

int main() {
	stack<char> st(2);
	//stack<char> st(2);//利用两者均可构造函数初始化
	char ch;
	try {
		st.push('m');
		st.push('k');
		st.push('v');
	}
	catch (stack<char>::Full) {//注意!!!此处FULL后面不需要括号!!!!!
		cout << "stack full!\n";
	}
	try {
		ch = st.pop();
		cout << ch << endl;
		ch = st.pop();
		cout << ch << endl;
		ch = st.pop();
		cout << ch << endl;
	}
	catch (stack<char>::Empty) //若栈为空,再进行出栈操作,则抛出异常
	{
		cout << "stack empty!\n";
	}

	double c;
	stack<double> sl(2);
	try {
		sl.push(6165.2);
		sl.push(65.2);
		sl.push(12.888);
	}
	catch (stack<double>::Full) {//注意!!!此处FULL后面不需要括号!!!!!
		cout << "stack full!\n";
	}
	try {
		c = sl.pop();
		cout << c << endl;
		c = sl.pop();
		cout << c << endl;
		c = sl.pop();
		cout << c << endl;
	}
	catch (stack<double>::Empty) {
		cout << "stack empty!\n";
	}
	return 0;
}

测试结果
在这里插入图片描述
在这里插入图片描述

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-01-17 11:25:24  更:2022-01-17 11:25:39 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 14:55:43-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码