JAVA數(shù)據(jù)結(jié)構(gòu)之漢諾塔代碼實例
本文實例為大家分享了JAVA數(shù)據(jù)結(jié)構(gòu)之漢諾塔的具體代碼,供大家參考,具體內(nèi)容如下
package p02.動態(tài)鏈表;
import p01.動態(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 自動生成的方法存根
list.addFrist(e);
}
@Override
public E pop() {
// TODO 自動生成的方法存根
return list.removeFrist();
}
@Override
public boolean isEmpty() {
// TODO 自動生成的方法存根
return list.isEmpty();
}
@Override
public E peek() {
// TODO 自動生成的方法存根
return list.getFrist();
}
@Override
public int getSize() {
// TODO 自動生成的方法存根
return list.getSize();
}
@Override
public void clear() {
// TODO 自動生成的方法存根
list.clear();
}
@Override
public String toString() {
// TODO 自動生成的方法存根
return list.toString();
}
}
//用前邊實現(xiàn)的鏈棧去實現(xiàn)漢諾塔
package p03.遞歸;
import p02.動態(tài)鏈表.LinkedStack;
public class Hano {
public static void main(String[] args) {
// String x = "x"; //原始盤
// String y = "y"; //借助盤
// String z = "z"; //最終盤
// 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);
}
//定義三個棧,實現(xiàn)其移動
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);
}
}
//只打印移動過程。
/*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)之漢諾塔詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Mybatis空值關(guān)聯(lián)的具體實現(xiàn)
在復(fù)雜的數(shù)據(jù)庫查詢中,處理空值關(guān)聯(lián)是一項常見的需求,本文就來介紹一下Mybatis空值關(guān)聯(lián)的具體實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-07-07
Java中WeakHashMap和HashMap的區(qū)別詳解
這篇文章主要介紹了Java中WeakHashMap和HashMap的區(qū)別詳解,WeakHashMap和HashMap一樣,WeakHashMap也是一個散列表,它存儲的內(nèi)容也是鍵值對(key-value)映射,而且鍵和值都可以為null,需要的朋友可以參考下2023-09-09
Idea中如何調(diào)出Run dashboard 或services窗口
這篇文章主要介紹了Idea中如何調(diào)出Run dashboard 或services窗口問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03
Java利用SpEL表達式實現(xiàn)權(quán)限校驗
這篇文章主要為大家詳細介紹了Java如何利用SpEL表達式實現(xiàn)權(quán)限校驗功能,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-01-01
Spring Boot中數(shù)據(jù)庫操作Druid和HikariDataSource的詳細過程
這篇文章主要介紹了Spring Boot中數(shù)據(jù)庫操作Druid和HikariDataSource的詳細過程,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-06-06

