Java数据结构中栈的用法
发表于:2024-10-11 作者:千家信息网编辑
千家信息网最后更新 2024年10月11日,这期内容当中小编将会给大家带来有关Java数据结构中栈的用法,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。栈是先进后出的特殊线性表,只允许在表的末端进行插入和删除,
千家信息网最后更新 2024年10月11日Java数据结构中栈的用法
这期内容当中小编将会给大家带来有关Java数据结构中栈的用法,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。
栈是先进后出的特殊线性表,只允许在表的末端进行插入和删除,后面将介绍两种实现栈的方式,分别是基于数组的实现、基于链表的实现。
栈的抽象定义
class Mystack{public: Mystack() {} virtual void push(int &x) = 0; virtual bool pop(int &x) = 0; virtual bool Top(int &x) const = 0; virtual bool IsEmpty()const = 0; virtual bool IsFull()const = 0; virtual int getSize()const = 0;};
顺序栈-----------使用数组表示栈空间
定义:
#pragma once#include "Mystack.h"#include#include using namespace std;const int stackIncreament = 20;class SeqStack : public Mystack{public: SeqStack(int sz = 50); //建立一个空栈 ~SeqStack() { delete[]elements; } //析构函数 //如果栈满,则溢出程序处理,否则插入x void push(int &x); //如果栈空,则返回FALSE,否则使用x传递栈顶的值,top-1 bool pop(int &x); //如果栈空,则返回FALSE,否则使用x传递栈顶的值 bool Top(int &x); //判断栈是否为空 bool IsEmpty()const { return (top == -1) ? true : false; } //判断栈是都为满 bool IsFull()const { return (top == maxSize - 1) ? true : false; } //获取栈当前的size int getSize()const { return top + 1; } //将栈置空 void MakeEmpty() { top = -1; } //重载 操作 << friend ostream& operator<<(ostream& os, SeqStack& s);private: int *elements; //栈数组指针 int top; //栈顶指针 int maxSize; //栈的最大容量 void overflowProcess(); //溢出处理程序};
实现:
#include "SeqStack.h"SeqStack::SeqStack(int sz):top(-1),maxSize(sz){ elements = new int[maxSize]; //创建栈的数组空间 assert(elements == NULL); //断言:动态分配是否成功}void SeqStack::push(int & x){ //首先判断栈是否已满,满则转入溢出处理 if(IsFull() == true){ overflowProcess(); } elements[++top] = x; //将top+1,再插入值x}bool SeqStack::pop(int & x){ //先判断是否为空,为空则返回FALSE if (IsEmpty() == true) { return false; } x = elements[top--]; //使用x返回top所指,再讲top-1 return true;}bool SeqStack::Top(int & x){ //空栈则为FALSE if (IsEmpty() == true) { return false; } //栈不为空,则返回栈顶元素的值 x = elements[top]; return true;}ostream& operator<<(ostream& os, SeqStack& s) { //输出栈中元素 os << "top = " << s.top << endl; for (int i = 0; i <= s.top; ++i) { os << i << ": " << s.elements[i] << endl; } return os;}void SeqStack::overflowProcess(){ //栈溢出时,扩充栈的存储空间 int *Newelement = new int[maxSize + stackIncreament]; if (Newelement == NULL) { cout << "分配内存失败"; exit(1); } for (int i = 0; i <= top; ++i) { Newelement[i] = elements[i]; } delete[] elements; elements = Newelement;}
上述就是小编为大家分享的Java数据结构中栈的用法了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注行业资讯频道。
数组
空间
处理
数据
数据结构
结构
元素
内容
指针
程序
分析
分配
最大
特殊
成功
专业
中小
先进
内存
内容丰富
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
共同维护网络安全宣传语
网络技术极限
计算科学软件开发
玩吃鸡如何变更服务器
滕州管理软件开发
叫车软件开发哪个好
泗洪软件开发文档
服务器各种数据是什么意思
软件开发好就业嘛
中国顶级网络安全公司有哪些
中国网吧数据库
公司外网系统网络安全防护
服务器打不开磁盘管理
sql数据库如何存到文件夹
小程序数据库动态添加字段
数据库 记录 字段的值
彩通网络技术有限公司怎么样
互联网电视科技
数据库管理编程题查询语句
向服务器端发送的请求
qq安全 锁定所有服务器
通渭软件开发有限公司
数据库安全审计 增强级
兴弘网络技术有限公司怎么样
服务器各种数据是什么意思
东莞哪家软件开发公司比较好
办公室网络安全规范
oracle数据库创建要求
中国省市数据库
windows11服务器管理器