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);
        }
    }
}
相关推荐
大猫子的技术日记几秒前
Playwright 自动化测试入门指南:Python 开发者的端到端实战
开发语言·人工智能·python
韩立学长10 分钟前
【开题答辩实录分享】以《夏日计划露营地管理系统的设计与实现》为例进行选题答辩实录分享
开发语言·python
Zachery Pole14 分钟前
JAVA_03_运算符
java·开发语言·前端
毕设源码-邱学长25 分钟前
【开题答辩全过程】以 基于java的网上书店管理系统为例,包含答辩的问题和答案
java·开发语言
Gogo81631 分钟前
同一个 new,不同的世界:Java 与 TypeScript 对象创建机制的降维打击
java·开发语言·typescript
你的冰西瓜37 分钟前
C++ STL算法——非修改序列算法
开发语言·c++·算法·stl
2501_9419820539 分钟前
2026马年大吉:基于 Java 的企微外部群主动调用体系
java·开发语言·企业微信
独自破碎E41 分钟前
题解 | 灵异背包?
android·java·开发语言
星火开发设计1 小时前
类模板:实现通用数据结构的基础
java·开发语言·数据结构·c++·html·知识