栈:后进先出;最后一个放入堆栈中的物体总是被最先拿出来。
使用链表来模拟栈的入栈出栈操作。
1.节点类代码
public class Entry<T> { private T value; private Entry<T> next; public Entry() { this(null); } public Entry(T value) { this.value=value; this.next=null; } public void setValue(T value) { this.value=value; } public void setNext(Entry<T> next) { this.next=next; } public T getValue() { return value; } public Entry<T> getNext(){ return next; } }
2.节点的入栈出栈方法代码
public class Link<T> {//链表实现栈,先进后出 private Entry<T> headEntry; private int size=0; public Link() { headEntry =new Entry<>(); } public void pop() {//出栈 if(headEntry.getNext()!=null) { headEntry.getNext().setValue(null); headEntry.setNext(headEntry.getNext().getNext()); size--; }else { return; } } public void push(T value) {//入栈 Entry<T> newEntry=new Entry<>(value); if(headEntry.getNext()!=null) { newEntry.setNext(headEntry.getNext()); } headEntry.setNext(newEntry); size++; } public void show(){//打印节点 if(headEntry.getNext()==null) { return; } for(Entry<T> p = headEntry.getNext();p!=null;p=p.getNext()){ System.out.print(p.getValue()+" "); } System.out.println(); } }
3.测试类代码
public class Main { public static void main(String args[]) { Link<String> ll=new Link<>(); ll.push("1");//入栈 ll.push("2"); ll.push("3"); ll.push("4"); ll.push("5"); ll.push("6"); ll.push("7"); ll.push("8"); ll.show();//打印栈内元素 ll.pop();//弹出栈顶元素 ll.show(); ll.pop(); ll.show(); } }
4.测试结果
以上所述是小编给大家介绍的java 使用链表来模拟栈的入栈出栈操作详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对小牛知识库网站的支持!
问题内容: 使用Java中的链表实现堆栈的最佳方法是什么? 编辑:我将最好的定义为最有效的使用干净的代码。我已经使用数组来实现堆栈,但是对链接列表不熟悉,因此想知道是否有人可以帮助我实现类似于以下内容的内容: 编辑:如果有人感兴趣,这是链表的实现。 问题答案: 假设您真的想从头开始,而不是使用现有的完美堆栈实现之一,那么我建议您: 创建一个“ MyStack ”类,该类实现所需的任何接口(也许列出
主要内容:链栈元素入栈,链栈元素出栈,总结链栈 ,即用链表实现栈存储结构。 链栈的实现思路同顺序栈类似,顺序栈是将数 顺序表(数组)的一端作为栈底,另一端为栈顶;链栈也如此,通常我们将链表的头部作为栈顶,尾部作为栈底,如图 1 所示: 图 1 链栈示意图 将链表头部作为栈顶的一端,可以避免在实现数据 "入栈" 和 "出栈" 操作时做大量遍历链表的耗时操作。 链表的头部作为栈顶,意味着: 在实现数据"入栈"操作时,需要将数据从链表的头部插入
所以我有一个堆栈,它允许典型的Push和Pop函数。我很难理解这一切实际上是如何在代码方面工作的。我在这里看到了这篇文章,最佳答案中的图片/图表,展示了列表是如何被“推”下来的,你指向最新的元素。我有一个 它挂接到结构“节点” 我如何结合一个推拉与"节点*下一步;"?最难理解的是我将如何真正做到这一点。我知道它最初指向空,然后如果我推一个2,4,6,它将是6,4,2,#。掌握如何实际使用链表中的指
Runtime data Area 什么是操作数栈? 与局部变量表一样,均以字长为单位的数组。不过局部变量表用的是索引,操作数栈是弹栈/压栈来访问。操作数栈可理解为java虚拟机栈中的一个用于计算的临时数据存储区。 存储的数据与局部变量表一致含int、long、float、double、reference、returnType,操作数栈中byte、short、char压栈前(bipush)会被转为
本文向大家介绍JavaScript 栈的详解及实例代码,包括了JavaScript 栈的详解及实例代码的使用技巧和注意事项,需要的朋友参考一下 JavaScript 栈 栈是一种遵从先进后出(LIFO)原则的有序集合。 新添加或待删除的元素都保存在栈的末尾,称作栈顶,另一端就叫栈底。 在栈里,新元素都靠近栈顶,旧元素都接近栈底 昨天因为有点事没有更新,今天打算给大家讲讲JavaScript实现的数
本文向大家介绍Python栈的实现方法示例【列表、单链表】,包括了Python栈的实现方法示例【列表、单链表】的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了Python栈的实现方法。分享给大家供大家参考,具体如下: Python实现栈 栈的数组实现:利用python列表方法 代码如下: 运行结果: 栈的长度: 4 items:['welcome', 'www', 'jb51', 'net