Java数据结构中栈的用法
发表于:2025-01-19 作者:千家信息网编辑
千家信息网最后更新 2025年01月19日,这期内容当中小编将会给大家带来有关Java数据结构中栈的用法,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。栈是先进后出的特殊线性表,只允许在表的末端进行插入和删除,
千家信息网最后更新 2025年01月19日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安全错误
数据库的锁怎样保障安全
电脑连接服务器的账号是啥
挖财网络技术有限公司规模多大
电商软件开发方案
软件开发什么方法确认收入
公安网络安全工资
河北辰星飞宇网络技术
数据库中日志文件后缀是什么
网络安全法 刑法解释
18大以来网络安全
方舟生存进化服务器帧率低
江苏微型软件开发特征
软件开发的五大要求
柳州ARM服务器
决策管理设置里的服务器是啥
阜新软件开发报价
新泰app软件开发公司有哪些
数据库 关系代数avb
为什么手机充话费显示服务器开小
网站无法访问未连接服务器
神州公司网络技术方案设计
一流的软件开发
洛阳巨人网络安全教育
上海全程软件开发
网络安全宣传广场舞
公安网络安全工资
数据库系统的构成为
网络安全工作法公安
网络安全绘画比赛图片a3
学网络技术应该从哪方面开始
网络安全命运体