Java栈之链式栈存储结构实现

一、链栈
采用单链表来保存栈中所有元素,这种链式结构的栈称为链栈。
二、栈的链式存储结构实现
package com.ietree.basic.datastructure.stack;
/**
* 链栈
*
* Created by ietree
* 2017/4/29
*/
public class LinkStack<T> {
// 定义一个内部类Node,Node实例代表链栈的节点
private class Node {
// 保存节点的数据
private T data;
// 指向下个节点的引用
private Node next;
// 无参构造器
public Node() {
}
// 初始化全部属性的构造器
public Node(T data, Node next) {
this.data = data;
this.next = next;
}
}
// 保存该链栈的栈顶元素
private Node top;
// 保存该链栈中已包含的节点数
private int size;
// 创建空链栈
public LinkStack() {
// 空链栈,top的值为null
top = null;
}
// 以指定数据元素来创建链栈,该链栈只有一个元素
public LinkStack(T element) {
top = new Node(element, null);
size++;
}
// 返回链栈的长度
public int length() {
return size;
}
// 进栈
public void push(T element) {
// 让top指向新创建的元素,新元素的next引用指向原来的栈顶元素
top = new Node(element, top);
size++;
}
// 出栈
public T pop() {
Node oldTop = top;
// 让top引用指向原栈顶元素的下一个元素
top = top.next;
// 释放原栈顶元素的next引用
oldTop.next = null;
size--;
return oldTop.data;
}
// 访问栈顶元素,但不删除栈顶元素
public T peek(){
return top.data;
}
// 判断链栈是否为空栈
public boolean empty() {
return size == 0;
}
// 请空链栈
public void clear() {
top = null;
size = 0;
}
public String toString() {
// 链栈为空栈时
if (empty()) {
return "[]";
} else {
StringBuilder sb = new StringBuilder("[");
for (Node current = top; current != null; current = current.next) {
sb.append(current.data.toString() + ", ");
}
int len = sb.length();
return sb.delete(len - 2, len).append("]").toString();
}
}
}
测试类:
package com.ietree.basic.datastructure.stack;
/**
* Created by ietree
* 2017/4/29
*/
public class LinkStackTest {
public static void main(String[] args) {
LinkStack<String> stack = new LinkStack<String>();
stack.push("aaaa");
stack.push("bbbb");
stack.push("cccc");
stack.push("dddd");
System.out.println(stack);
System.out.println("访问栈顶元素:" + stack.peek());
System.out.println("第一次弹出栈顶元素:" + stack.pop());
System.out.println("第二次弹出栈顶元素:" + stack.pop());
System.out.println("两次pop之后的栈:" + stack);
}
}
程序输出:
[dddd, cccc, bbbb, aaaa] 访问栈顶元素:dddd 第一次弹出栈顶元素:dddd 第二次弹出栈顶元素:cccc 两次pop之后的栈:[bbbb, aaaa]
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
# Java栈之链式栈存储结构
# Java栈之存储
# Javasript设计模式之链式调用详解
# Java及Android中常用链式调用写法简单示例
# java队列实现方法(顺序队列
# 链式队列
# 循环队列)
# JAVA 实现二叉树(链式存储结构)
# JAVA中实现链式操作(方法链)的简单例子
# java中实体类转Json的2种方法
# java中实体类和JSON对象之间相互转化
# java反射遍历实体类属性和类型
# 并赋值和获取值的简单方法
# Java实体类实现链式操作实例解析
# 链式
# 弹出
# 两次
# 为空
# 希望能
# 只有一个
# 谢谢大家
# 但不
# 下个
# 值为
# 链表
# lt
# gt
# data
# private
# Node
# 空链栈
# null
# size
# top
相关文章:
常州自助建站费用包含哪些项目?
攀枝花网站建设,攀枝花营业执照网上怎么年审?
在线ppt制作网站有哪些软件,如何把网页的内容做成ppt?
MySQL查询结果复制到新表的方法(更新、插入)
如何高效生成建站之星成品网站源码?
如何在Windows虚拟主机上快速搭建网站?
企业微网站怎么做,公司网站和公众号有什么区别?
开源网站制作软件,开源网站什么意思?
湖州网站制作公司有哪些,浙江中蓝新能源公司官网?
C++如何将C风格字符串(char*)转换为std::string?(代码示例)
如何做网站制作流程,*游戏网站怎么搭建?
建站主机数据库如何配置才能提升网站性能?
如何在新浪SAE免费搭建个人博客?
孙琪峥织梦建站教程如何优化数据库安全?
建站之星如何实现五合一智能建站与营销推广?
b2c电商网站制作流程,b2c水平综合的电商平台?
c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗
,交易猫的商品怎么发布到网站上去?
建站之星多图banner生成与模板自定义指南
购物网站制作公司有哪些,哪个购物网站比较好?
利用JavaScript实现拖拽改变元素大小
建站之星安装提示数据库无法连接如何解决?
如何选择高效可靠的多用户建站源码资源?
如何安全更换建站之星模板并保留数据?
企业宣传片制作网站有哪些,传媒公司怎么找企业宣传片项目?
网站制作大概多少钱一个,做一个平台网站大概多少钱?
家庭建站与云服务器建站,如何选择更优?
成都网站制作公司哪家好,四川省职工服务网是做什么用?
,制作一个手机app网站要多少钱?
长沙企业网站制作哪家好,长沙水业集团官方网站?
网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?
如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?
如何快速生成ASP一键建站模板并优化安全性?
创业网站制作流程,创业网站可靠吗?
制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?
惠州网站建设制作推广,惠州市华视达文化传媒有限公司怎么样?
建站主机如何选?高性价比方案全解析
如何破解联通资金短缺导致的基站建设难题?
建站之星微信建站一键生成小程序+多端营销系统
宝华建站服务条款解析:五站合一功能与SEO优化设置指南
小程序网站制作需要准备什么资料,如何制作小程序?
如何撰写建站申请书?关键要点有哪些?
如何快速生成凡客建站的专业级图册?
平台云上自助建站如何快速打造专业网站?
免费视频制作网站,更新又快又好的免费电影网站?
如何选择适配移动端的WAP自助建站平台?
如何选购建站域名与空间?自助平台全解析
如何用wdcp快速搭建高效网站?
如何在万网开始建站?分步指南解析
定制建站平台哪家好?企业官网搭建与快速建站方案推荐
*请认真填写需求信息,我们会在24小时内与您取得联系。