java使用鏈棧實現數制轉換

來源:互聯網
上載者:User

標籤:

java實現鏈棧在前面有所介紹:http://www.cnblogs.com/lixiaolun/p/4644141.html

 

將前面java實現鏈棧的代碼稍作修改:

package linkedstack;public class LinkStack {private Element base;private Element top;class Element{public Object data;public Element next;}/** * 初始化棧 * */public void initStack(){top = new Element();base = new Element();top.data=null;top.next=base;base.data=null;base.next=null;}/** * 入棧 * */public 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;}}/** * 出棧 * */public Object pop(){Object o = null;if(top.next==base){System.out.println("棧中沒有元素!");return o;}else{o = top.next.data;//System.out.println("出棧操作"+o);top.next=top.next.next;}return o;}/** * 判斷棧是否為空白 * */public Boolean isEmpty(){if(top.next==base){return true;}return false;}/** * 列印棧 * */public 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();}}

  

java實現數制轉換的類的代碼:

package stackapplication;import linkedstack.LinkStack;public class Conversion {public static void main(String[] args) {LinkStack lStack = new LinkStack();lStack.initStack();int N = 100;//原始十進位數int X = 2;//要轉化成X進位數while(N!=0){lStack.push(N%X);N=N/X;}while(!lStack.isEmpty()){System.out.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.