java實現鏈棧

來源:互聯網
上載者:User

標籤:

前面學習了java實現順序棧:http://www.cnblogs.com/lixiaolun/p/4644134.html

接下來,學習java實現鏈棧。

鏈棧類代碼:

package linkedstack;public class LinkStack {private Element base;private Element top;class Element{public Object data;public Element next;}/** * 初始化棧 * */void initStack(){top = new Element();base = new Element();top.data=null;top.next=base;base.data=null;base.next=null;}/** * 入棧 * */void push(Object o){Element e = new Element();e.data = o;if(top.next==base)//第一次入棧操作{e.next=base;top.next=e;}else{e.next=top.next;top.next=e;}}/** * 出棧 * */void pop(){if(top.next==base){System.out.println("棧中沒有元素!");}else{System.out.println("出棧操作"+top.next.data);top.next=top.next.next;}}/** * 列印棧 * */void print(){System.out.print("列印棧:");Element temp =top;while(temp.next!=base){System.out.print(temp.next.data+"\t");temp =temp.next;}System.out.println();}}

鏈棧測試類別代碼:

package linkedstack;public class LinkStackMain {public static void main(String[] args) {LinkStack lStack = new LinkStack();lStack.initStack();lStack.pop();lStack.push(1);lStack.push(2);lStack.push(3);lStack.push(4);lStack.print();lStack.pop();lStack.pop();lStack.print();lStack.pop();lStack.pop();lStack.print();lStack.pop();}}

  

 

java實現鏈棧

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.