汉诺塔问题java代码_汉诺塔问题编程算法

汉诺塔问题java代码_汉诺塔问题编程算法代码:packagecom.wangyq.datastructrue.arithmetic;importjava.util.Arrays;importjava.util.Stack;/***分治算法-汉罗塔*/publicclassDivideAndConquer{publicstaticvoidmain(String[]args){//定义一个汉罗塔TowerofHanoitowerofHanoi=newT

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

代码:

package com.wangyq.datastructrue.arithmetic;

import java.util.Arrays;
import java.util.Stack;

/** * 分治算法-汉罗塔 */
public class DivideAndConquer { 
   
    public static void main(String[] args) { 
   
        //定义一个汉罗塔
        TowerofHanoi towerofHanoi = new TowerofHanoi(4);
        towerofHanoi.show();
        towerofHanoi.hannoi();
    }

}

class TowerofHanoi { 
   
    int tier = 0;
    Stack column1 = new Stack();
    Stack column2 = new Stack();
    Stack column3 = new Stack();

    TowerofHanoi(int tier) { 
   
        this.tier = tier;
        //初始化汉罗塔
        for (int i = tier; i > 0; i--) { 
   
            column1.push(i);
        }
    }

    /** * 打印汉罗塔 */
    public void show() { 
   
        System.out.println("汉罗塔:");
        System.out.println("第一根柱子" + Arrays.toString(column1.toArray()));
        System.out.println("第二根柱子" + Arrays.toString(column2.toArray()));
        System.out.println("第三根柱子" + Arrays.toString(column3.toArray()));
    }


    public void hannoi() { 
   
        move(tier, column1, column2, column3);
    }

    /** * 汉罗塔移动 */
    public void move(int tier, Stack stack1, Stack stack2, Stack stack3) { 
   
        if (tier == 1) { 
   
            //只有一个直接移上去
            stack3.push(stack1.pop());
            show();
        } else { 
   
            //
            move(tier - 1, stack1, stack3, stack2); //将n-1个在A柱子的盘子通过c柱子移动到B柱子
            stack3.push(stack1.pop());
            show();                                       //将A柱子上编号为n的盘子移动到c柱子
            move(tier - 1, stack2, stack1, stack3);  //将在B柱子的n-1盘子通过A柱子移动到C柱子
        }
    }
}

结果:
汉罗塔:
第一根柱子[4, 3, 2, 1]
第二根柱子[]
第三根柱子[]
汉罗塔:
第一根柱子[4, 3, 2]
第二根柱子[1]
第三根柱子[]
汉罗塔:
第一根柱子[4, 3]
第二根柱子[1]
第三根柱子[2]
汉罗塔:
第一根柱子[4, 3]
第二根柱子[]
第三根柱子[2, 1]
汉罗塔:
第一根柱子[4]
第二根柱子[3]
第三根柱子[2, 1]
汉罗塔:
第一根柱子[4, 1]
第二根柱子[3]
第三根柱子[2]
汉罗塔:
第一根柱子[4, 1]
第二根柱子[3, 2]
第三根柱子[]
汉罗塔:
第一根柱子[4]
第二根柱子[3, 2, 1]
第三根柱子[]
汉罗塔:
第一根柱子[]
第二根柱子[3, 2, 1]
第三根柱子[4]
汉罗塔:
第一根柱子[]
第二根柱子[3, 2]
第三根柱子[4, 1]
汉罗塔:
第一根柱子[2]
第二根柱子[3]
第三根柱子[4, 1]
汉罗塔:
第一根柱子[2, 1]
第二根柱子[3]
第三根柱子[4]
汉罗塔:
第一根柱子[2, 1]
第二根柱子[]
第三根柱子[4, 3]
汉罗塔:
第一根柱子[2]
第二根柱子[1]
第三根柱子[4, 3]
汉罗塔:
第一根柱子[]
第二根柱子[1]
第三根柱子[4, 3, 2]
汉罗塔:
第一根柱子[]
第二根柱子[]
第三根柱子[4, 3, 2, 1]

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/182891.html原文链接:https://javaforall.net

(0)
上一篇 2022年10月12日 上午9:36
下一篇 2022年10月12日 上午9:36


相关推荐

  • 阈值分割法——最佳阈值的选择问题

    阈值分割法——最佳阈值的选择问题阈值分割法可以说是图像分割中的经典方法 它利用图像中要提取的目标与背景在灰度上的差异 通过设置阈值来把像素级分成若干类 从而实现目标与背景的分离 一般流程 通过判断图像中每一个像素点的特征属性是否满足阈值的要求 来确定图像中的该像素点是属于目标区域还是背景区域 从而将一幅灰度图像转换成二值图像 用数学表达式来表示 则可设原始图像 f x y T 为阈值 分割图像时则满足下式

    2026年3月26日
    2
  • redux-saga学习

    redux-saga学习如果redux需要用到sideeffect异步操作,redux-thunk和redux-saga绝对是目前两个最受欢迎的中间件插件。redux-saga是一个用于管理redux应用异步操作的中间件,redux-saga通过创建sagas将所有异步操作逻辑收集在一个地方集中处理,可以用来代替redux-thunk中间件。

    2026年1月24日
    5
  • Android ContentProvider 的使用&源码分析(Android Q)

    Android ContentProvider 的使用&源码分析(Android Q)本文详细讲解了 ContentProvi 从安装包中解析 ContentProvi 的创建 注册 发布等各个过程 以及介绍了 ContentProvi 的简单使用

    2026年3月18日
    1
  • Python requests_html 爬取多语言网站内容与翻译策略

    Python requests_html 爬取多语言网站内容与翻译策略

    2026年3月12日
    1
  • jsp显示时间的代码_空调代码大全

    jsp显示时间的代码_空调代码大全请参照以下的原代码,注意:下面的JavaScript码可以放置于想要显示时间的任意位置。以下是网页源代码您在本站逗留了varsec=0;varmin=0;varhou=0;flag=0;idt=window.setTimeout(“update();”,1000);functionupdate(){sec++;if(sec==60){sec=0;min+=1;}if(min

    2022年8月30日
    6
  • sublime 激活码(注册激活)

    (sublime 激活码)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

    2022年3月29日
    215

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号