堆栈在Java编程中无处不在,作为重要的数据结构类型之一,本篇使用了三种方式(数组\链表\共享数组空间)来实现堆栈,并且对一些经典的应用方法进行了定义,欢迎阅览ㄟ(◑‿◐ )ㄏ
前言
LIFO(先进后出)的一种线性表,栈的优点是存取速度快,仅次于寄存器,并且栈的数据是可共享的,但是存放在栈的数据的大小和生存周期是固定的,缺乏一定的灵活性。在本篇对栈的实现使用的是链表与数组的形式,因为这两种形式简化了在ArrayList和LinkedList中的逻辑。

数组形式对栈实现
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 
 | public class Stack<E> {
 private Object[] data;
 private int maxsize;
 private int top;
 
 public Stack(){
 this(5);
 }
 
 public Stack(int maxsize) {
 if(maxsize>0) {
 this.maxsize = maxsize;
 data = new Object[maxsize];
 top = -1;
 }else {
 System.out.println("初始化长度不能为0及小于0");
 }
 }
 
 public boolean isEmpty() {
 return top==-1;
 }
 
 public void push(Object o) {
 if(top>=maxsize-1) {
 System.out.println("栈满,无法放入新元素");
 }else {
 data[++top] = o;
 }
 }
 
 public E peek() {
 if(isEmpty()) {
 System.out.println("栈空,无栈顶元素");
 return null;
 }else {
 return (E)data[top];
 }
 }
 
 public E pop() {
 if(isEmpty()){
 System.out.println("栈空,无栈顶元素");
 return null;
 }else {
 return (E)data[top--];
 }
 }
 
 public int search(E order) {
 int toptem = top;
 while(top!=-1) {
 if(data[top]==order) {
 break;
 }else {
 --top;
 }
 }
 int result = ++top;
 top = toptem;
 return result;
 }
 public static void main(String[] args) {
 Stack mystack= new Stack(6);
 mystack.push(1);
 mystack.push(2);
 mystack.push(3);
 mystack.push(4);
 System.out.println("mystack 是否为空?"+mystack.isEmpty());
 System.out.println("mystack的栈顶元素为:"+mystack.peek());
 System.out.println("依次出栈前两个:"+mystack.pop()+mystack.pop());
 System.out.println("此时栈顶元素为:"+mystack.peek());
 System.out.println("元素1此时在栈中的位置为:"+mystack.search(2));
 }
 
 | 
链表形式堆栈实现
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 
 | public class LinkStack<T> {
 Node<T> top = null;
 
 class Node<T>{
 private T data;
 private Node<T> next=null;
 public Node(T data) {
 this.data = data;
 }
 }
 
 public void push(T data) {
 Node<T> newnode = new Node<T>(data);
 newnode.next = top;
 top = newnode;
 }
 
 public T pop() {
 if(top==null) {
 return null;
 }
 T data = top.data;
 top = top.next;
 return data;
 }
 
 public boolean isEmpty() {
 return top==null;
 }
 
 public T peek() {
 if(top==null) {
 return null;
 }
 return top.data;
 }
 public static void main(String[] args) {
 LinkStack ls = new LinkStack();
 ls.push(1);
 ls.push(6);
 ls.push(2);
 System.out.println("栈是否为空:"+ls.isEmpty());
 System.out.println(ls.pop());
 System.out.println(ls.pop());
 System.out.println(ls.pop());
 System.out.println("取出栈顶元素:"+ls.peek());
 }
 }
 
 | 
3.共享数组空间的双重栈形式
| 12
 3
 4
 5
 6
 7
 8
 9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
 100
 101
 102
 103
 104
 105
 106
 107
 108
 109
 110
 111
 112
 113
 114
 115
 116
 117
 118
 119
 
 | public class DoubleStack {
 private int maxsize = 20;
 private int topl;
 private int topr;
 private int[] data;
 public DoubleStack() {
 data = new int[maxsize];
 topl = -1;
 topr = maxsize;
 }
 
 public boolean isEmpty() {
 return ((topl==0)&&(topr==maxsize));
 }
 
 public boolean isFull() {
 return (topl+1==topr);
 }
 
 public void clearStack() {
 topl = -1;
 topr = maxsize;
 }
 
 public int length() {
 if(isEmpty()) {
 return 0;
 }
 if(isFull()) {
 return maxsize;
 }
 int length = (topl+1)+(maxsize-topr);
 return length;
 }
 
 public int getLeftStack() {
 if(topl==-1) {
 System.out.println("左栈什么都没有喔~");
 return 0;
 }
 return data[topl];
 }
 
 public int getRightStack() {
 if(topr==maxsize) {
 System.out.println("右栈什么都没有喔~");
 return 0;
 }
 return data[topr];
 }
 
 public void push(String stackdir, int e) {
 if(isFull()) {
 System.out.println("嘻嘻嘻栈满啦,不能再入啦~~");
 return ;
 }
 if(stackdir=="左栈") {
 topl+=1;
 data[topl]=e;
 return ;
 }
 if(stackdir=="右栈") {
 topr-=1;
 data[topr]=e;
 return ;
 }
 }
 
 public int pop(String stackdir) {
 int result;
 if(isEmpty()) {
 System.out.println("555这里什么都没有,不能再出了~~~");
 return -1;
 }
 if(stackdir=="左栈") {
 result = data[topl--];
 return result;
 }
 if(stackdir=="右栈") {
 result = data[topr++];
 return result;
 }
 return 0;
 }
 
 public void stackTraverse() {
 int i=0;
 while(i<=topl) {
 System.out.println(data[i]+" ");
 i++;
 }
 i = topr;
 while(i<maxsize) {
 System.out.println(data[i]+" ");;
 i++;
 }
 }
 public static void main(String[] args) {
 DoubleStack stack = new DoubleStack();
 System.out.println("此时栈为空吗?"+stack.isEmpty());
 stack.push("左栈", 1);
 stack.push("左栈", 2);
 stack.push("左栈", 3);
 stack.push("右栈", 4);
 stack.push("右栈", 5);
 stack.push("右栈", 6);
 System.out.println("此时栈的长度为:"+stack.length());
 System.out.println("我放入了一些元素,此时栈为空吗?"+stack.isEmpty());
 System.out.println("我想看看左栈栈顶是什么:"+stack.getLeftStack());
 System.out.println("我还想看右栈栈顶是什么:"+stack.getRightStack());
 System.out.print("让我看看栈里面都有什么吧:");
 stack.stackTraverse();
 System.out.println("我想弹出一些左栈的元素"+stack.pop("左栈")+stack.pop("左栈"));
 System.out.println("我想弹出一些右栈的元素"+stack.pop("右栈")+stack.pop("右栈"));
 System.out.print("现在栈里都还剩哪些元素呢?:");
 stack.stackTraverse();
 }
 }
 
 |