Java与C++分别用递归实现汉诺塔详解

yizhihongxing

Java与C++分别用递归实现汉诺塔详解

1. 理论背景

汉诺塔是一个经典的递归问题,它可以用于验证一个编程语言是否具备递归能力。

汉诺塔由三根针和若干个圆盘组成,每个圆盘有一个固有的大小,这些圆盘可以滑动到任意一根针上,但是每次只能移动一个圆盘并且大的圆盘不能放在小的圆盘上面。使用递归的方式可以让我们轻松找出三个针上的圆盘移动方法。

2. 递归实现

Java实现

public class Hanoi {
    public void move(int n, char from, char to, char mid) {
        if (n == 1) {
            System.out.println("Move disk 1 from " + from + " to " + to);
        } else {
            move(n - 1, from, mid, to);
            System.out.println("Move disk " + n + " from " + from + " to " + to);
            move(n - 1, mid, to, from);
        }
    }
}

这个 Java 代码中的 move 方法使用了 3 个参数:圆盘的数量 n 和三个针 from, to, mid。如上面所述,当 n 等于 1 时,只需要将当前针上编号为 1 的圆盘移动到目标针即可。当 n 大于 1 时,将编号大于 1 的圆盘移动到辅助针上,再将编号为 1 的圆盘移到目标针上,最后将编号大于 1 的圆盘从辅助针移到目标针上。

C++实现

#include <iostream>

using namespace std;

void move(int n, char from, char to, char mid) {
    if (n == 1) {
        cout << "Move disk 1 from " << from << " to " << to << endl;
    } else {
        move(n - 1, from, mid, to);
        cout << "Move disk " << n << " from " << from << " to " << to << endl;
        move(n - 1, mid, to, from);
    }
}

int main() {
    int n = 3;
    char A = 'A';
    char B = 'B';
    char C = 'C';
    move(n, A, C, B);
    return 0;
}

这个 C++ 代码也是与上面 Java 的方式实现类似,也是使用递归,当 n 等于 1 时输出移动的指令, n 大于 1 时出错移动。

3. 示例说明

示例一

有 4 个圆盘需要从 A 柱移到 C 柱,则输出:

Java实现:

Move disk 1 from A to B
Move disk 2 from A to C
Move disk 1 from B to C
Move disk 3 from A to B
Move disk 1 from C to A
Move disk 2 from C to B
Move disk 1 from A to B
Move disk 4 from A to C
Move disk 1 from B to C
Move disk 2 from B to A
Move disk 1 from C to A
Move disk 3 from B to C
Move disk 1 from A to B
Move disk 2 from A to C
Move disk 1 from B to C

C++实现:

Move disk 1 from A to C
Move disk 2 from A to B
Move disk 1 from C to B
Move disk 3 from A to C
Move disk 1 from B to A
Move disk 2 from B to C
Move disk 1 from A to C
Move disk 4 from A to B
Move disk 1 from C to B
Move disk 2 from C to A
Move disk 1 from B to A
Move disk 3 from C to B
Move disk 1 from A to C
Move disk 2 from A to B
Move disk 1 from C to B

示例二

需要将5个圆盘从A柱移到C柱,则输出:

Java实现:

Move disk 1 from A to B
Move disk 2 from A to C
Move disk 1 from B to C
Move disk 3 from A to B
Move disk 1 from C to A
Move disk 2 from C to B
Move disk 1 from A to B
Move disk 4 from A to C
Move disk 1 from B to C
Move disk 2 from B to A
Move disk 1 from C to A
Move disk 3 from B to C
Move disk 1 from A to B
Move disk 2 from A to C
Move disk 1 from B to C
Move disk 5 from A to B
Move disk 1 from C to A
Move disk 2 from C to B
Move disk 1 from A to B
Move disk 3 from C to A
Move disk 1 from B to C
Move disk 2 from B to A
Move disk 1 from C to A
Move disk 4 from C to B
Move disk 1 from A to B
Move disk 2 from A to C
Move disk 1 from B to C
Move disk 3 from A to B
Move disk 1 from C to A
Move disk 2 from C to B
Move disk 1 from A to B

C++实现:

Move disk 1 from A to C
Move disk 2 from A to B
Move disk 1 from C to B
Move disk 3 from A to C
Move disk 1 from B to A
Move disk 2 from B to C
Move disk 1 from A to C
Move disk 4 from A to B
Move disk 1 from C to B
Move disk 2 from C to A
Move disk 1 from B to A
Move disk 3 from C to B
Move disk 1 from A to C
Move disk 2 from A to B
Move disk 1 from C to B
Move disk 5 from A to C
Move disk 1 from B to A
Move disk 2 from B to C
Move disk 1 from A to C
Move disk 3 from B to A
Move disk 1 from C to B
Move disk 2 from C to A
Move disk 1 from B to A
Move disk 4 from B to C
Move disk 1 from A to C
Move disk 2 from A to B
Move disk 1 from C to B
Move disk 3 from A to C
Move disk 1 from B to A
Move disk 2 from B to C
Move disk 1 from A to C

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Java与C++分别用递归实现汉诺塔详解 - Python技术站

(0)
上一篇 2023年6月27日
下一篇 2023年6月27日

相关文章

  • stringbuilder去除最后一个多余的字符的方法

    StringBuilder去除最后一个多余的字符的方法 在开发过程中,我们经常会需要拼接字符串。但是拼接完成之后,由于一些原因,最后一个字符可能变成了多余的字符。这个时候,就需要使用StringBuilder类来去除这个多余字符了。 StringBuilder类简介 StringBuilder是Java API中用于处理字符串的类,与String类不同的是,…

    其他 2023年3月29日
    00
  • 基于laravelrequest的所有方法详解

    以下是基于Laravel Request的所有方法详解的完整攻略: Laravel Request是一个用于处理HTTP请求的类,它提供了许多有用的方法来获取请求参数、文件、头信息等。以下是一些常用的方法: 获取请求参数 我们可以使用以下方法来获取请求参数: $request->input(‘key’, ‘default’); 该方法返回请求参数中名为…

    other 2023年5月8日
    00
  • Android原生态实现分享转发功能实例

    Android原生态实现分享转发功能实例攻略 介绍 在Android应用中实现分享转发功能是一项常见的需求。本攻略将详细介绍如何使用Android原生态实现分享转发功能,并提供两个示例说明。 步骤 步骤一:添加分享按钮 首先,在你的布局文件中添加一个分享按钮,可以使用ImageButton或者ImageView来实现。例如: <ImageButton …

    other 2023年9月7日
    00
  • MySQL之递归小问题

    MySQL中实现递归操作一般通过存储过程实现,这里提供一下通用的步骤: 创建存储过程 CREATE PROCEDURE recursion_procedure() BEGIN /*这里编写递归存储过程的具体内容*/ END; 定义变量 在存储过程中需要定义一个变量,用于判断递归是否应该终止。一般情况下,变量应该初始化为0。 DECLARE variable_…

    other 2023年6月27日
    00
  • C++基于递归和非递归算法判定两个二叉树结构是否完全相同(结构和数据都相同)

    下面是 C++ 基于递归和非递归算法判定两个二叉树结构是否完全相同(结构和数据都相同)的详细攻略: 问题分析 题目要求我们判断两个二叉树的结构和数据是否完全相同。这里所说的“结构相同”指的是两棵树的节点数、节点的左右子树结构相同,而“数据相同”指的是两棵树的节点存储的数据值相等。 递归算法实现 递归是二叉树算法中最经典的算法之一,而判断两个二叉树结构是否相同…

    other 2023年6月27日
    00
  • 学习YUI.Ext 第四天–对话框Dialog的使用

    学习YUI.Ext 第四天–对话框Dialog的使用 概述 在前端界面开发中,对话框(Dialog)是经常使用的组件。在YUI.Ext中,也提供了对话框的组件。本文将介绍如何使用YUI.Ext的对话框组件。 Dialog组件的使用 引入Dialog组件 在使用Dialog组件前需要首先引入YUI.Ext的库文件和YUI.Ext的样式文件。可以使用下面的代码…

    other 2023年6月27日
    00
  • 学信网用户名忘了怎么办?学信网帐号找回用户名的解决方法

    学信网用户名忘了怎么办?学信网帐号找回用户名的解决方法 1. 可以通过学信网官方网站找回用户名 步骤如下: 打开学信网官方网站(http://www.chsi.com.cn)。 点击网站右上角的“登录”按钮并进入登录页面。 在登录页面点击下方的“忘记用户名?”。 在弹出的页面中输入您的身份证号和姓名,并选择您的证件类型和证件号。 点击“下一步”按钮,按照页面…

    other 2023年6月27日
    00
  • uni-appios的threejs本地obj、mtl文件的读取

    简介 在uni-app中,可以使用three.js库来创建3D图形。如果要在iOS设备上使用three.js库,可以使用本地obj和mtl文件来加载3D模型。本攻略将详细讲解如何在uni-app中使用three库加载本地obj和mtl文件。 步骤 下面是在uni-app中three.js库加载本地obj和mtl文件的步骤: 在uni-app项目中安装thre…

    other 2023年5月8日
    00
合作推广
合作推广
分享本页
返回顶部