链式栈——Java实现
1 package struct;
2
3 //接口
4 interface ILinkStack{
5 //栈中元素个数(栈大小)
6 int size();
7 //取栈顶元素
8 Object top();
9 //判断栈是否为空
10 boolean isEmpty();
11 //入栈
12 Object pop();
13 //出栈
14 Object push(Object value);
15 //清空栈
16 void clear();
17 }
18
19 //工厂类
20 class Factory2{
21 private Factory2(){}
22 public static ILinkStack getILinkStackInstance(){
23 return new LinkStackImpl();
24 }
25 }
26
27 class LinkStackImpl implements ILinkStack {
28 //栈顶元素
29 Node top;
30 //链表长度记录入栈元素
31 private int count;
32 class Node{
33 Node prev;
34 Node next;
35 Object data;
36 public Node(Object data) {
37 this.data = data;
38 }
39 }
40
41 public int size() {
42 return count;
43 }
44
45 public Object top() {
46 return top.data;
47 }
48 //判栈空
49 public boolean isEmpty() {
50 return (size()==0);
51 }
52 //入栈
53 public Object push(Object value) {
54 Node node = new Node(value);
55 if(top == null){
56 top = node;
57 }else{
58 top.next = node;
59 node.prev = top;
60 top = top.next;
61 }
62 count++;
63 return top;
64 }
65 public void print(){
66 System.out.println("从栈顶到栈底打印栈中元素:");
67 myPrint(top);
68 return;
69 }
70 //栈顶->栈底打印链表
71 private void myPrint(Node top){
72 for(Node node = top;node!=null;node=node.prev){
73 System.out.print(node.data+" ");
74 }
75 }
76 //出栈
77 public Object pop() {
78 Node node = top;
79 if(top == null){
80 System.out.println("空栈无要出栈元素");
81 return -1;
82 }else{
83 top = top.prev;
84 node.prev = null;
85 node.data = null;
86 }
87 count--;
88 return top();
89 }
90 //清空栈
91 public void clear(){
92 Node node1 = top;
93 for(Node node = top;node!=null;){
94 node = node.prev;
95 node1.data = null;
96 node1.prev = null;
97 count--;
98 }
99 }
100 }
101 public class LinkStack {
102 public static void main(String[] args) {
103 ILinkStack linkStack = Factory2.getILinkStackInstance();
104 //向下转型
105 LinkStackImpl linkStack1 = (LinkStackImpl)linkStack;
106 System.out.println("============测试isEmpty函数(空栈)=================");
107 System.out.println(linkStack.isEmpty());
108 System.out.println("============测试push和print函数=================");
109 linkStack.push(5);
110 linkStack.push(9);
111 linkStack.push(10);
112 linkStack.push(1);
113 linkStack.push(8);
114 linkStack.push(12);
115 linkStack.push(6);
116 linkStack.push(3);
117 linkStack1.print();
118 System.out.println();
119 System.out.println("============入栈后测试top函数=================");
120 System.out.println(linkStack.top());
121 System.out.println("============入栈后测试size函数=================");
122 System.out.println(linkStack.size());
123 System.out.println("============测试pop和print函数=================");
124 linkStack.pop();
125 linkStack.pop();
126 linkStack.pop();
127 linkStack1.print();
128 System.out.println();
129 System.out.println("============出站后测试top函数=================");
130 System.out.println(linkStack.top());
131 System.out.println("============出栈后测试size函数=================");
132 System.out.println(linkStack.size());
133 System.out.println("============测试clear后size函数=================");
134 linkStack.clear();
135 System.out.println(linkStack.size());
136 }
137 }

链式栈——Java实现的更多相关文章
- Spark案例分析
一.需求:计算网页访问量前三名 import org.apache.spark.rdd.RDD import org.apache.spark.{SparkConf, SparkContext} /* ...
- java 实现简单的链式栈
package com.my; /** * 链式栈 * @author wanjn * */ public class LinkedStack { private Node head; private ...
- Java的顺序栈和链式栈
栈的定义 栈是限制在表的一段进行插入和删除的运算的线性表,通常能够将插入.删除的一端为栈顶,例外一端称为栈底,当表中没有任何元素的时候称为空栈. 通常删除(又称"退栈")叫做弹出p ...
- Java栈之链式栈存储结构实现
一.链栈 采用单链表来保存栈中所有元素,这种链式结构的栈称为链栈. 二.栈的链式存储结构实现 package com.ietree.basic.datastructure.stack; /** * 链 ...
- 数据结构笔记--栈的总结及java数组实现简单栈结构
杂谈"栈"结构: 栈(Stack)是一种插入删除操作都只能在一个位置上进表,这个位置位于表的末端,叫做栈顶(Top). 对栈的基本操作有push和pop,表示进栈和出栈.也就相当于 ...
- java 静态内部类小总结
内部类是指在一个外部类的内部再定义一个类.内部类作为外部类的一个成员,并且依附于外部类而存在的.内部类可为静态,可用protected和private修饰(而外部类只能使用public和缺省的包访问权 ...
- 数据结构栈的java实现
近来复习数据结构,自己动手实现了栈.栈是一种限制插入和删除只能在一个位置上的表.最基本的操作是进栈和出栈,因此,又被叫作“先进后出”表. 实现方式是这样的:首先定义了一个接口,然后通过这个接口实现了线 ...
- 【Java数据结构学习笔记之二】Java数据结构与算法之栈(Stack)实现
本篇是java数据结构与算法的第2篇,从本篇开始我们将来了解栈的设计与实现,以下是本篇的相关知识点: 栈的抽象数据类型 顺序栈的设计与实现 链式栈的设计与实现 栈的应用 栈的抽象数据类型 栈是 ...
- 栈详解及java实现
导读 栈和队列是有操作限制的线性表. 目录 1.栈的概念.特点.存储结构. 2.栈的java实现及运用. 概念 栈是一种只允许在一端进行插入或删除的线性表. 1.栈的操作端通常被称为栈顶,另一端被称为 ...
随机推荐
- Language Server for Java™ 1.0 在VS Code上正式发布!
Nick Zhu form Senior Program Manager, Developer Division at Microsoft 今天,我们很高兴与大家宣布:Language Server ...
- 记一次 php-fpm 连接 nginx 的错误。
环境: docker 中 centos 镜像下 yum 安装的php,nginx. [root@lnmp1 /]# php -v PHP 7.2.11 (cli) (built: Oct 9 2018 ...
- windows 系统文件夹挂载到 Linux 系统,拷贝(发送)文件到 windows 系统,实现异地备份
1.在windows 系统上配置好共享文件夹,用来接收Linux 系统的文件 注意:关闭windows 系统防火墙,或者添加进出站规则 2.在Linux 系统中,创建需要拷贝的文件目录 #mkdi ...
- C++ 类中 关于常量定义 理解总结
前言 有时我们希望某些常量只在类中有效.由于#define定义的宏常量是 全局 的,不能达到目的,于是想当然地觉得应该用 const修饰 数据成员来实现.const数据成员的确是存在的,但其含义却不是 ...
- Python基础入门(1)- Python环境搭建与基础语法
Python编程环境搭建 Python环境搭建 官网下载:https://www.python.org/ python --version PyCharm下载安装 安装 官网下载:https://ww ...
- nohup、&、 2>&1详解
前言 对一个程序员来说,java项目的打包部署也是一项必须掌握的一项技术任务,现我将自己平时在maven下打包以及部署项目总结,希望对有这方面诉求的小伙伴有所帮助! 一.maven项目打包及命令 (1 ...
- 《Python语言程序设计》【第2周】Python基本图形绘制
实例2:Python蟒蛇绘制 #PythonDraw.py import turtle #import 引入了一个绘图库 turtle 海龟库--最小单位像素 turtle.setup(650, 35 ...
- 《Python语言程序设计》【第1周】Python基本语法元素
实例:温度转化 #TempConvert.py 单行注释 ''' TemConvert.py ''' # 多行注释 TempStr = input("请输入带有符号的温度值: ") ...
- Qt Creator 源码学习笔记01,初识QTC
阅读本文大概需要 4 分钟 Qt Creator 是一款开源的轻量级 IDE,整个架构代码全部使用 C++/Qt 开发而成,非常适合用来学习C++和Qt 知识,这也是我们更加深入学习Qt最好的方式,学 ...
- centos7系列的网络yum源配置
因为新安装centos机器yum比较旧,主要是对网易源进行配置,其它源也差不多.我是在securecrt远程ssh工具操作的,非虚拟机软件上. yum install lszrz -y 安装上传工 ...