栈的定义
栈(Stack)是限制仅在表的一端进行插入和删除运算的线性表。
(1)通常称插入、删除的这一端为栈顶(Top),另一端称为栈底(Bottom)。
(2)当表中没有元素时称为空栈。
(3)栈为后进先出(LastInFirstOut)的线性表,简称为LIFO表。
栈的修改是按后进先出的原则进行。每次删除(退栈)的总是当前栈中"
最新"的元素,即最后插入(进栈)的元素,而最先插入的是被放在栈的底部,
要到最后才能删除。
【示例】元素是以a1,a2,…,an的顺序进栈,退栈的次序却是an,an-1,…,
a1。
2、栈的基本运算
(1)InitStack(S)
构造一个空栈S。
(2)StackEmpty(S)
判栈空。若S为空栈,则返回TRUE,否则返回FALSE。
(3)StackFull(S)
判栈满。若S为满栈,则返回TRUE,否则返回FALSE。
注意:该运算只适用于栈的顺序存储结构。
(4)Push(S,x)
进栈。若栈S不满,则将元素x插入S的栈顶。
(5)Pop(S)
定义堆栈ADT
StackADT
packageStack;
publicinterfaceStackADT{
publicvoidpush(Objectelement);//压栈
publicObjectpop();//出栈
publicbooleanisEmpty();
publicintsize();
publicObjectpeek();//返回栈顶对象的一个引用
publicStringtoString();
}
链式实现:
在栈的一段添加和删除元素,在栈中维护一个指向栈顶的结点和一个count变量指示栈的大小:
privateLinearNodetop;//指向栈顶
privateintcount;//标记栈的大小
每次出栈和压栈在链表的表头:(也可以再表尾,实现方式不一样而已)
top--->元素1--->元素2--->元素3.........
实现(附带测试main):
LinkedStack
packageStack;
importBag.LinearNode;
//为了重点来实现算法,将异常情况直接打印出然后退出程序,不再声明异常类
publicclassLinkedStackimplementsStackADT{
privateLinearNodetop;//指向栈顶
privateintcount;//标记栈的大小
publicstaticvoidmain(String[]args){
LinkedStackstack=newLinkedStack();
System.out.println("将0到10依次压栈");
for(inti=0;i<10;i++)
stack.push(i);
System.out.println("连续执行5次出栈操作");
for(inti=0;i<5;i++)
stack.pop();
System.out.println("栈为空吗?:"+stack.isEmpty());
System.out.println("栈的大小为:"+stack.size());
System.out.println("栈顶元素为:"+stack.top.getElement());
System.out.println("栈顶元素为:"+stack.peek());
}
publicLinkedStack()
{
top=null;
count=0;
}
publicintsize(){
returncount;
}
publicbooleanisEmpty(){
return(size()==0);
}
publicvoidpush(Objectelement){
LinearNodenode=newLinearNode(element);
node.setNext(top);
top=node;
count++;
}
publicObjectpop(){
if(isEmpty())
{
System.out.println("stackisempty!");
System.exit(1);
}
Objectresult=top.getElement();
top=top.getNext();
count--;
returnresult;
}
publicObjectpeek(){
Objectresult=top.getElement();
returnresult;
}
}
运行结果:
将0到10依次压栈
连续执行5次出栈操作
栈为空吗?:false
栈的大小为:5
栈顶元素为:4
栈顶元素为:4
数组实现:
栈底总是数组下标为0的位置,入栈出栈从数组下标的最后一个元素开始:
privateObject[]contents;
privateinttop;//top标记下一个入栈的位置,同时也表示栈的容量大小,跟链式实现的count比较一下!!!
实现(附带测试main):
ArrayStack
packageStack;
publicclassArrayStackimplementsStackADT{
privateObject[]contents;
privateinttop;//top标记下一个入栈的位置,同时也表示栈的容量大小,跟链式实现的count比较一下!!!
privatestaticintSIZE=10;
publicArrayStack()
{
contents=newObject[SIZE];
top=0;
}
publicvoidexpand(){//借助于申请一个辅助空间,每次扩展容量一倍
Object[]larger=newObject[size()*2];
for(intindex=0;index<top;index++)
larger[index]=contents[index];
contents=larger;
}
publicintsize(){
returntop;
}
publicbooleanisEmpty(){
return(size()==0);
}
publicvoidpush(Objectelement){
//if(isEmpty())
//expand();
if(top==contents.length)
expand();
contents[top]=element;
top++;
}
publicObjectpop(){
if(isEmpty())
{
System.out.println("stackisempty!");
System.exit(1);
}
Objectresult=contents[top-1];
contents[top-1]=null;//出栈
top--;
returnresult;
/*书上这样写简便一点:::
*top--;
*Objectresult=contents[top];
*contents[top]=null;*/
}
publicObjectpeek(){
Objectresult;
if(isEmpty())
result=null;
else
result=contents[top-1];
returnresult;
}
publicstaticvoidmain(String[]args){
ArrayStackstack=newArrayStack();
System.out.println("将0到24依次压栈,然后连续10次出栈");
for(inti=0;i<25;i++)
stack.push(i);
for(inti=0;i<10;i++)
stack.pop();
System.out.println("栈的大小为:"+stack.size());
System.out.println("栈为空吗?:"+stack.isEmpty());
System.out.println("栈顶元素为:"+stack.peek());
}
}
运行结果:
将0到24依次压栈,然后连续10次出栈
栈的大小为:15
栈为空吗?:false
栈顶元素为:14
分享到:
相关推荐
主要介绍了Java定义栈结构,并实现入栈、出栈操作,结合完整实例形式分析了java数据结构中栈的定义、以及入栈、出栈、栈是否为空判断、栈大小计算、打印栈元素等相关操作技巧,需要的朋友可以参考下
用java实现的栈Stack类,不继承任何集合类,用对象数组实现
1个班的50份java作业:类设计 实现栈的基本结构 小型计算器
java数字栈和符号栈模拟计算器(中缀表达式) “计算中缀表达式”可以称得上是一个特别经典的关于栈的算法题,几乎在所有数据结构教材中都会涉及,而且很多公司面试或者笔试的时候都会把这道题作为一个考察点。可以说...
Java语言编写的数据结构-栈的实现,包括顺序栈和链栈。
包含链表、 栈、 队列、优先级队列、哈希表,绝对原创总结!
数据结构(Java)实践作业迷宫参考书本使用栈结构实现的
主要介绍了java数据结构实现栈,需要的朋友可以参考下
栈的顺序存储结构及Java实现 //MyStack.java public class MyStack { int MAX_SIZE = 100; int top; String[] stack; public void init(String[] array){ stack = new String[100]; top = -1; for (int i = ...
栈和队列的基本操作及其应用 1、掌握栈和队列的顺序存储结构和链式存储结构,以便在实际中灵活应用。...3、掌握栈和队列的基本运算,如:入栈与出栈,入队与出队等运算在顺序存储结构和链式存储结构上的实现。 回文判断
主要介绍了Java中使用数组实现栈数据结构实例,本文先是讲解了实现栈至少应该包括以下几个方法等知识,然后给出代码实例,需要的朋友可以参考下
基于JAVA实现的常用数据结构代码,JAVA实现复杂度、动态数组、链表、栈、队列、二叉搜索树等
数据结构的定义 数据结构是计算机存储、组织数据的方式,用于高效地访问和修改数据。...Java提供了丰富的数据结构库,包括数组、链表、栈、队列等,这些数据结构为程序员提供了处理各种问题的工具和方法。
主要介绍了用Java代码实现栈数据结构的基本方法归纳,各种算法的实现也是ACM上经常出现的题目,是计算机学习的基本功,需要的朋友可以参考下
栈 链表 队列 图 操作系统 linux 代码控制 自动化代码检查 sonar 代码规范 阿里巴巴Java开发规范手册 UMPAY——编码规范 日志规范 异常规范 网络 协议 TCP/IP HTTP hession file HTTPS 负载...
Java-用数组实现栈-队列-线性列表(最详细) 有注释 适合java新生 进行数组的练习 3个数据结构的数组实现练习
Java版数据结构代码,最好解压后直接导入到eclipse中,因为有些代码间有关联关系。其中栈结构中的压栈方法中包含了动态数组的实现方法,没有单写了,在队列的代码中,引用了链表的代码
主要介绍了Java数据结构之栈的基本定义与实现方法,简单描述了数据结构中栈的功能、原理,并结合java实例形式分析了栈的基本定义与使用方法,需要的朋友可以参考下
《计算机科学丛书·数据结构从应用到实现(Java版)》系统地介绍了数据结构以及数据结构与对象之间的联系。主要内容包括:算法效率的输入规模、阶和大O,数据结构的无序和有序列表,队列和栈基于数组和链表的设计实例...
数据结构和算法分析(java)实现中第三章知识点的总结,主要讲的是表。栈、队列的原理和实现,以及应用。一共17页。