JAVA从零开始实现数据结构九:链栈
2018-04-04 本文已影响0人
FireflieX
链式栈类似于单链表操作,只需要记录top指针即可
完整的MyLinkedStack类
import java.util.Arrays;
/**
* Created by FireFlies on 2018/4/3.
*clearStack(): 将栈清空。
*isStackEmpty(): 若栈为空, 返回true, 否则返回false。
*getTop(): 若栈存在且非空, 用e返回S的栈顶元素。
*push(E e): 若栈存在, 插入新元素e到栈S中并成为栈顶元素。
*pop(): 删除栈中栈顶元素, 并用e返回其值。
*stackLength(): 返回栈的元素个数。
*/
public class MyLinkedStack {
private int capacity = 0;
private Node top = null; //保存该链栈的栈顶元素
public class Node{
private Object o;
private Node next = null;
public Node(){}
public Node(Object o){this.o = o;}
}
/**
*进栈操作push
* 类似于顺序表的add操作,在尾部加入元素
*/
public boolean push(Object o){
Node newNode = new Node(o);
newNode.next = top;
top = newNode;
capacity++;
return true;
}
/**
* 出栈操作pop
* 删除尾部元素
*/
public Object pop(){
if(this.stackLength()<=0)
throw new RuntimeException("栈为空");
top = top.next;
capacity--;
return top.o;
}
/**
* 若栈存在且非空, 用e返回栈顶元素。
*/
public Object getTop(){
if(this.stackLength()<=0)
throw new RuntimeException("栈为空");
return top.o;
}
/**
* 返回栈的元素个数。
* @return
*/
public int stackLength() {
return this.capacity;
}
/**
* 若栈为空, 返回true, 否则返回false。
*/
public boolean isStackEmpty(){
if(this.stackLength()==0)
return true;
return false;
}
/**
* 将栈清空。
*/
public boolean clearStack(){
capacity = 0;
return true;
}
/**
* 获取指定index的元素
* @return
*/
public Object get(int index) {
validateIndex(index);
Node temp = top;
Object result = null;
for(int i=0; i<this.stackLength();i++){
if(i == index){
result = temp.o;
}
temp = temp.next;
}
return result;
}
/**
* 验证当前下标是否合法,如果不合法,抛出运行时异常
* @param index 下标
*/
private void validateIndex(int index) {
if (index < 0 || index > this.stackLength()) {
throw new RuntimeException("数组index错误:" + index);
}
}
/**
* 输出当前线性表所有元素
*/
public void print(){
System.out.print("[");
for(int i=0;i<this.stackLength();i++){
System.out.print(this.get(i).toString()+" ");
}
System.out.println("]");
}
}
测试类
/**
* Created by FireFlies on 2018/4/3.
*/
public class MyLinkedStackTest {
public static void main(String[] args) {
MyLinkedStack myLinkedStack = new MyLinkedStack();
//测试进栈操作
System.out.println("测试进栈操作:");
myLinkedStack.push(new Integer(1));
myLinkedStack.print();
myLinkedStack.push(new Integer(2));
myLinkedStack.print();
myLinkedStack.push(new Integer(3));
myLinkedStack.print();
//测试getTop
System.out.println("查看栈顶元素");
System.out.println("Stack top: "+myLinkedStack.getTop().toString());
//测试出栈操作
System.out.println("测试出栈操作:");
System.out.println("出栈元素:"+myLinkedStack.pop().toString());
myLinkedStack.print();
System.out.println("出栈元素:"+myLinkedStack.pop().toString());
myLinkedStack.print();
//测试清空操作
System.out.println("测试清空操作");
myLinkedStack.clearStack();
System.out.println("Stack empty: "+myLinkedStack.isStackEmpty());
}
}
测试结果
image.png