千家信息网

Java数据结构中栈的用法

发表于:2025-11-12 作者:千家信息网编辑
千家信息网最后更新 2025年11月12日,这期内容当中小编将会给大家带来有关Java数据结构中栈的用法,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。栈是先进后出的特殊线性表,只允许在表的末端进行插入和删除,
千家信息网最后更新 2025年11月12日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安全错误 数据库的锁怎样保障安全 网络技术总监任职资格 闵行区网络软件开发销售电话 红鸟软件开发公司 杭州亦盛网络技术 广州市润宝软件开发发服务 运城市网络安全宣传活动 僵尸毁灭工程服务器设置多大内存 婺源租房网络安全 大家一起做好网络安全工作 创建数据库的索引库 山东传奇网络技术服务有限公司 设计合理的网络安全型号 数据库运维岗位 软件开发市场趋势应对策略 reaxy数据库是免费的吗 数据库money 机关网络安全事件 网络安全手抄报六年级简单 服务器虚拟化应用技术规范 如何通过服务器查信息 如何将音乐存入sql数据库 合肥app手机软件开发公司 剑灵哪个服务器人多 秦美人一键端 找不到数据库 梦幻西游网页版新服务器开启时间 重庆互联网信息科技有限公司 服务器登陆不默认管理员账户 网络安全法 时间风险增大 计算机网络技术学些什么内容 与网络安全相关的股票
0