用LinkedList方法模拟栈的数据结构
Posted 北极村
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用LinkedList方法模拟栈的数据结构相关的知识,希望对你有一定的参考价值。
import java.util.LinkedList;
/**
*
* @author Ginfer
* @virsion
* HP
* linkedlist
* HP
* 自定义栈集合
* 栈的数据结构是先进后出,
*/
public class MyStack {
//创建一个成员对象
private LinkedList link;
//添加一个构造方法,并默认new一个LinkedList对象
//当创建MyStack对象的时候其实默认是在底层创建了一个LinkedList对象
public MyStack() {
link=new LinkedList();
}
//调用栈的压栈,其实就是调用了LinkedList的addFirst()方法
public void add(Object obj){
link.addFirst(obj);
}
//调用栈的弹栈,其实就是调用了LinkedList的removeFirst()方法,弹栈以后数据将不存在栈中,所以用remove
public Object get(){
//return link.getFirst();
return link.removeFirst();
}
//需要判断栈中是否为空,所以就调用了LinkedList的isEmpty()方法来判断
public boolean isEmpty(){
return link.isEmpty();
}
}
import java.util.Iterator;
import java.util.LinkedList;
import Test.MyStack;
/**
*
* @author Ginfer
* @virsion
* HP
* Linkedlist
* HP
*
* 使用Linklist模拟栈数据结构的集合,并测试
* 意思是自己定义一个集合类,在这个集合内部可以使用LinkedList模拟
*
*/
public class TestLinklist {
public static void main(String[] args) {
/*
* myStack测试
*/
MyStack ms=new MyStack();
ms.add("asd");
ms.add("qwe");
ms.add("zxc");
while (!ms.isEmpty()){
System.out.println(ms.get());
}
}
}
以上是关于用LinkedList方法模拟栈的数据结构的主要内容,如果未能解决你的问题,请参考以下文章
java 16 - 5 LinkedList模拟栈数据结构的集合
数据结构C语言篇《三》栈和队列概念,模拟函数实现,以及相关OJ面试题
数据结构C语言篇《三》栈和队列概念,模拟函数实现,以及相关OJ面试题