Java 的棧基本原理

來源:互聯網
上載者:User
棧的工作原理:先進先後出,類似美國郵件處理原理,收到郵件按時間的降序(從以前的日期到距離現在最近日期方式累加,在堆積的郵件最上面第一封距離現在


時間最近的郵件),從最上面的第一封郵件開始看,直到最後一封為止.


下面是類比其原理代碼:
package dataStoreStructure;
/**
 * 類比棧的工作原理(先進後出)
 * 如果使用數組來實現棧,先要規定數組的大小,但使用鏈表則不需要規定數組的大小
 * 訪問棧元素時,只能訪問最上面一個元素,不能訪問除上面外的元素
 * @author tfq
 * @datetime 2011-10-10
 */
public class SimulationStack {
 //size of stack array
 private int maxSize;
 private long[] stackArray;
 //top of stack
 private int top;
 
 public SimulationStack(int size){
  //set array size
  maxSize=size;
  //create array
  stackArray=new long[maxSize];
  top=-1;
 }
 
 /**
  * put item on top of stack
  * @param j
  */
 public void push(long j){
  //stack array is not full
  if(!this.isFull()){
   //increment top,insert item
   stackArray[++top]=j;
  }else{
   System.out.println("stack array is full!");
  }
 }
 
 /**
  * take item from top of stack
  * @return
  */
 public long pop(){
  //stack array is not empty
  if(!this.isEmpty()){
   //access item,decrement top
   return stackArray[top--];
  }else{
   return -1;
  }
 }
 
 /**
  * peek at top of stack
  * @return at top item of stack array
  */
 public long peek(){
  return stackArray[top];
 }
 
 /**
  * true if stack is empty
  * @return
  */
 public boolean isEmpty(){
  return (top==-1);
 }
 
 /**
  * true if stack is full
  * @return
  */
 public boolean isFull(){
  return (top==maxSize-1);
 }
 
 public static void main(String[] args) {
  SimulationStack ss=new SimulationStack(30);
  //push item into stack
  ss.push(10);
  //peek push item
  System.out.println(ss.peek());
  ss.push(25);
  System.out.println(ss.peek());
  ss.push(30);
  System.out.println(ss.peek());
  ss.push(40);
  System.out.println(ss.peek());
  ss.push(50);  
  System.out.println(ss.peek());
  
  while(!ss.isEmpty()){
   //take item pop from stack array
   long tempValue=ss.pop();
   //peek pop item from stack array
   System.out.println("pop="+tempValue);
  }
    
 }
}

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.