JAVA數(shù)據(jù)結(jié)構(gòu)之漢諾塔代碼實(shí)例
本文實(shí)例為大家分享了JAVA數(shù)據(jù)結(jié)構(gòu)之漢諾塔的具體代碼,供大家參考,具體內(nèi)容如下
package p02.動(dòng)態(tài)鏈表; import p01.動(dòng)態(tài)數(shù)組.Stack; public class LinkedStack<E> implements Stack<E> { private LinkedList<E> list; public LinkedStack(){ list=new LinkedList<>(); } @Override public void push(E e) { // TODO 自動(dòng)生成的方法存根 list.addFrist(e); } @Override public E pop() { // TODO 自動(dòng)生成的方法存根 return list.removeFrist(); } @Override public boolean isEmpty() { // TODO 自動(dòng)生成的方法存根 return list.isEmpty(); } @Override public E peek() { // TODO 自動(dòng)生成的方法存根 return list.getFrist(); } @Override public int getSize() { // TODO 自動(dòng)生成的方法存根 return list.getSize(); } @Override public void clear() { // TODO 自動(dòng)生成的方法存根 list.clear(); } @Override public String toString() { // TODO 自動(dòng)生成的方法存根 return list.toString(); } }
//用前邊實(shí)現(xiàn)的鏈棧去實(shí)現(xiàn)漢諾塔 package p03.遞歸; import p02.動(dòng)態(tài)鏈表.LinkedStack; public class Hano { public static void main(String[] args) { // String x = "x"; //原始盤(pán) // String y = "y"; //借助盤(pán) // String z = "z"; //最終盤(pán) // move(x,y,z,N); int N=10; LinkedStack<Integer> stackX=new LinkedStack(); for(int i=N;i>=1;i--){ stackX.push(i); } LinkedStack<Integer> stackY=new LinkedStack(); LinkedStack<Integer> stackZ=new LinkedStack(); move(stackX,stackY,stackZ,N); System.out.println(stackX); System.out.println(stackZ); } //定義三個(gè)棧,實(shí)現(xiàn)其移動(dòng) public static void move(LinkedStack<Integer> x,LinkedStack<Integer> y, LinkedStack<Integer> z, int level) { if(level==1){ z.push(x.pop()); }else{ move(x,z,y,level-1); z.push(x.pop()); move(y,x,z,level-1); } } //只打印移動(dòng)過(guò)程。 /*public static void move(String x, String y, String z, int level) { if(level==1){ System.out.println(x+"->"+z); return; } move(x,z,y,level-1); System.out.println(x+"->"+z); move(y,x,z,level-1); }*/ }
以上所述是小編給大家介紹的JAVA數(shù)據(jù)結(jié)構(gòu)之漢諾塔詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
Mybatis空值關(guān)聯(lián)的具體實(shí)現(xiàn)
在復(fù)雜的數(shù)據(jù)庫(kù)查詢中,處理空值關(guān)聯(lián)是一項(xiàng)常見(jiàn)的需求,本文就來(lái)介紹一下Mybatis空值關(guān)聯(lián)的具體實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-07-07Java中WeakHashMap和HashMap的區(qū)別詳解
這篇文章主要介紹了Java中WeakHashMap和HashMap的區(qū)別詳解,WeakHashMap和HashMap一樣,WeakHashMap也是一個(gè)散列表,它存儲(chǔ)的內(nèi)容也是鍵值對(duì)(key-value)映射,而且鍵和值都可以為null,需要的朋友可以參考下2023-09-09SpringBoot中JPA更新時(shí)部分字段無(wú)效
本文主要介紹了SpringBoot中JPA更新時(shí)部分字段無(wú)效,在通過(guò)注解自動(dòng)更新時(shí),部分字段在調(diào)試時(shí)可以找到,卻沒(méi)有被自動(dòng)更新到數(shù)據(jù)庫(kù)中,下面就介紹一下解決方法2023-04-04SpringMvc獲取頁(yè)面中的參數(shù)方法詳解
這篇文章主要介紹了SpringMvc獲取頁(yè)面中的參數(shù)方法詳解,獲取頁(yè)面的參數(shù)通常都是讓類實(shí)現(xiàn)設(shè)置HttpServletRequest request接口然后重寫(xiě)接口中的方法的辦法來(lái)得到參數(shù),但是在Springmvc中有其他的獲取方法,需要的朋友可以參考下2023-10-10Idea中如何調(diào)出Run dashboard 或services窗口
這篇文章主要介紹了Idea中如何調(diào)出Run dashboard 或services窗口問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03Java利用SpEL表達(dá)式實(shí)現(xiàn)權(quán)限校驗(yàn)
這篇文章主要為大家詳細(xì)介紹了Java如何利用SpEL表達(dá)式實(shí)現(xiàn)權(quán)限校驗(yàn)功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-01-01Spring Boot中數(shù)據(jù)庫(kù)操作Druid和HikariDataSource的詳細(xì)過(guò)程
這篇文章主要介紹了Spring Boot中數(shù)據(jù)庫(kù)操作Druid和HikariDataSource的詳細(xì)過(guò)程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-06-06