java栈--数据结构


前言

java实现数据结构栈:用顺序表存储的栈和数组存储的栈。


本文源代码网址:https://gitee.com/zfranklin/java/tree/master/dataStructure/src/com/njupt/stack

https://gitee.com/zfranklin/java/tree/master/dataStructure/src/com/njupt/stack

栈的性质

数据先进后出。

好比一个瓶子,口径刚好装下一块方糖:

每次存数据只能在瓶子上方存,取数据也只能从瓶子上方一个一个取,顺序不能错。

数组栈

我们学过了 顺序存储(数组/顺序表)和链式存储(链表)。如果选用数组来表示栈。成员变量有一个数组,一个top表示栈顶(瓶口)数据的下标。

java 复制代码
public class ArrayStack<T> {
	 private T values[];
	 private int top;

和顺序表一样,采用泛型,支持任何数据类型。构造函数也和顺序表类似,有无参和有参两种。这里top要初始化为-1,因为top表示的是栈顶数据的下标,而顺序表的size表示的是数据个数,当然这个根据自己喜好设定top的意义。比如我设定为下标,当有第一个数据进来时this.top++;this.top就变成了0,也就是第一个数据的下标。

栈添加数据叫做push,取出数据叫pop,获得栈顶数据但不取出叫top,约定俗成。push依然要考虑扩容。还增加了isEmpty和isFull判断是否空,是否满的方法。

链表栈

链表栈和数组栈相比也就是存储方式不同。既然是链式存储,少不了结点Node,在链式栈类中写一个Node类,同样是泛型 < T >。

java 复制代码
class Node<T>
{
	T value;
	Node<T> next;
	
	public Node(T value)
	{
		this.value = value;
		this.next = null;
	}
}

栈的成员变量只需要头结点即可,头结点进行push--头插、pop--头删。

由于链式存储按需分配,不需要初始化时提前分配空间。无需自写构造方法。

push就是头插,在C语言专栏--链表里讲过,java大同小异;pop就是头删;top就是获取头结点的值;判空就是判断head头结点是否为null。没有判满一说,因为链式存储按需分配。

总结

两种方法表示 数据结构--栈。都比较简洁明了。

相关推荐
日月云棠几秒前
3 Dubbo 2.7 高级配置:检查控制、版本策略与协议选择
java·后端
计算机安禾1 分钟前
【c++面向对象编程】第40篇:单例模式(Singleton)的多种C++实现
开发语言·c++·单例模式
Harm灬小海3 分钟前
【云计算学习之路】学习Centos7系统-Linux软件包管理
linux·运维·服务器·学习·云计算·yum·rpm
砍材农夫6 分钟前
物联网 基于netty构建mqtt协议规范(主题通配符订阅)
java·前端·javascript·物联网·netty
掉鱼的猫10 分钟前
用 Solon AI 从零构建 MCP 工具服务:让 AI Agent 拥有真实世界的能力
java·llm·mcp
魔法阵维护师10 分钟前
从零开发游戏需要学习的c#模块,第十七章(显示真正的图片——精灵绘制)
学习·游戏
婷婷_17210 分钟前
JTAG (IEEE 1149.1)学习记录
学习·程序人生·debug·芯片·jtag·phy·eth/pcie
LuminousCPP12 分钟前
数据结构 - 线性表第三篇:基于顺序表实现 C 语言通讯录(基础功能篇)
c语言·数据结构·经验分享·笔记·算法
_日拱一卒16 分钟前
LeetCode:114二叉树展开为链表
java·开发语言·算法
ygkl969817 分钟前
未完待续 模拟题
学习