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。没有判满一说,因为链式存储按需分配。

总结

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

相关推荐
tgethe2 小时前
java并发——1
java·开发语言·面试
coder_zh_2 小时前
Java基础-学习-面试-校招-要点突击检查
java
郑州光合科技余经理2 小时前
海外O2O系统源码剖析:多语言、多货币架构设计与二次开发实践
java·开发语言·前端·小程序·系统架构·uni-app·php
冬夜戏雪7 小时前
实习面经摘录(九)
学习
arvin_xiaoting7 小时前
OpenClaw学习总结_I_核心架构_8:SessionPruning详解
前端·chrome·学习·系统架构·ai agent·openclaw·sessionpruning
工程师老罗8 小时前
Image(图像)的用法
java·前端·javascript
leo_messi948 小时前
2026版商城项目(一)
java·elasticsearch·k8s·springcloud
globaldomain8 小时前
什么是用于长距离高速传输的TCP窗口扩展?
开发语言·网络·php
美味蛋炒饭.8 小时前
Tomcat 超详细入门教程(安装 + 目录 + 配置 + 部署 + 排错)
java·tomcat
沈阳信息学奥赛培训8 小时前
#undef 指令 (C/C++)
c语言·开发语言·c++