C# 使用递归方法实现汉诺塔步数计算

C# 使用递归方法实现汉诺塔步数计算

  • [Part 1 什么是递归](#Part 1 什么是递归)
  • [Part 2 汉诺塔](#Part 2 汉诺塔)
  • [Part 3 程序](#Part 3 程序)

Part 1 什么是递归

举一个例子:计算从 1 到 x 的总和

c 复制代码
public int SumFrom1ToX(int x)
{
    if(x == 1)
    {
        return 1;
    }
    else
    {
        int result = x + SumFrom1ToX_2(x - 1);  // 调用自己
        return result;
    }
}

Part 2 汉诺塔

有三个石柱,在最左侧的石柱上从小到大摆放 N 层盘片,需要从最左侧的石柱移动到最右侧的石柱上,中间的石柱作为缓冲,一次只能移动一个盘片,且无论何时较小的盘片始终在较大的盘片上面。

这个问题求解这过程中搬运的次数

Part 3 程序

创建一个Move函数来移动盘子

c 复制代码
static void Move(int pile, char src, char temp, char dst)
{

}

pile 是最左侧的盘片数量,src 是起始点,temp 是中间的缓冲区,dst 是终点

c 复制代码
Move(pile - 1, src, dst, temp); // 将pile-1层盘片从src经过dst移动到temp
Move(1, src, temp, dst); // 将最底层的盘片从src移动到dst
Move(pile - 1, tmp, src, dst); // 将pile-1层汉诺塔从temp经过src移动到dst

Move 方法的代码

c 复制代码
static void Move(int pile, char src, char temp, char dst)
{
    if (pile == 1)
    {
        Console.WriteLine($"{src} --> {dst}");
        steps++;
        return;
    }

    Move(pile - 1, src, dst, temp);
    Move(1, src, temp, dst);
    Move(pile - 1, temp, src, dst);
}

完整代码

c 复制代码
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleHelloWorld
{
    class Hanoi
    {
        public static int steps = 0;

        public void ShowHanoiPath(int levels)
        {
            Console.WriteLine("输入的汉诺塔层数是:{0}", levels);
            Move(levels, 'A', 'B', 'C');
            Console.WriteLine("一共移动了{0}次", steps);
        }

        static void Move(int pile, char src, char temp, char dst)
        {
            if (pile == 1)
            {
                Console.WriteLine($"{src} --> {dst}");
                steps++;
                return;
            }

            Move(pile - 1, src, dst, temp);
            Move(1, src, temp, dst);
            Move(pile - 1, temp, src, dst);
        }
    }

    class Program
    {
        static void Main(string[] args)
        {
            Hanoi hanoi = new Hanoi();
            hanoi.ShowHanoiPath(4);
        }
    }
}
相关推荐
XKSYA(小巢校长)39 分钟前
NatGo我的世界联机篇
开发语言·php
Cons.W42 分钟前
Codeforces Round 975 (Div. 1) C. Tree Pruning
c语言·开发语言·剪枝
憧憬成为原神糕手1 小时前
c++_ 多态
开发语言·c++
VBA63371 小时前
VBA信息获取与处理第三个专题第三节:工作薄在空闲后自动关闭
开发语言
wjs20242 小时前
XSLT 实例:掌握 XML 转换的艺术
开发语言
萧鼎2 小时前
Python第三方库选择与使用陷阱避免
开发语言·python
安冬的码畜日常2 小时前
【D3.js in Action 3 精译_029】3.5 给 D3 条形图加注图表标签(上)
开发语言·前端·javascript·信息可视化·数据可视化·d3.js
一颗星星辰2 小时前
C语言 | 第十章 | 函数 作用域
c语言·开发语言
lxp1997412 小时前
php函数积累
开发语言·php
科技资讯早知道2 小时前
java计算机毕设课设—坦克大战游戏
java·开发语言·游戏·毕业设计·课程设计·毕设