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"; //原始盤
// 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);
}
//定義三個(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)過程。
/*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ì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
SpringBoot整合WxJava開啟消息推送的實(shí)現(xiàn)
本文主要介紹了SpringBoot整合WxJava開啟消息推送,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-03-03
Spring實(shí)現(xiàn)上拉刷新和下拉加載效果
這篇文章主要為大家詳細(xì)介紹了Spring實(shí)現(xiàn)上拉刷新和下拉加載效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-12-12
java中hashmap的底層數(shù)據(jù)結(jié)構(gòu)與實(shí)現(xiàn)原理
Hashmap是java面試中經(jīng)常遇到的面試題,大部分都會(huì)問其底層原理與實(shí)現(xiàn),本人也是被這道題問慘了,為了能夠溫故而知新,特地寫了這篇文章,以便時(shí)時(shí)學(xué)習(xí)2021-08-08
java搭建一個(gè)Socket服務(wù)器響應(yīng)多用戶訪問
本篇文章主要介紹了java搭建一個(gè)Socket服務(wù)器響應(yīng)多用戶訪問,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-02-02
解決JSTL foEach標(biāo)簽 刷新報(bào)錯(cuò)的方法
本篇文章是對(duì)JSTL foEach標(biāo)簽刷新報(bào)錯(cuò)的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05

