【C#】汉诺塔C#代码实现(递归)

news2024/9/20 23:48:19

1. 思路

假设总共需要移动n个盘子:

  1. A柱上的n-1个盘子借助C柱移向B柱
  2. A柱上仅剩的最后一个盘子移向C柱
  3. B柱上的n-1个盘子借助A柱移向C柱

2.代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace ConsoleDesktop
{
    class Program
    {
        static void Main(string[] args)
        {
            HanoiTower hanoi = new HanoiTower();
            int sum = hanoi.hanoiTowerSum(3, 'a', 'b', 'c');
            Console.WriteLine("总移动次数:{0}", sum);
        }
    }

    class HanoiTower
    {
        private void hanoiMove(char x, char y)
        {
            Console.WriteLine("{0} -> {1}", x, y);
        }

        public int hanoiTowerSum(int cnt, char a, char b, char c)
        {
            if(cnt == 1)
            {
                hanoiMove(a, c);
                return 1;
            }
            else
            {
                int sum = 0;
                sum += hanoiTowerSum(cnt - 1, a, c, b);		//步骤1
                hanoiMove(a, c); sum += 1;					//步骤2
                sum += hanoiTowerSum(cnt - 1, b, a, c);		//步骤3

                return sum;
            }
        }
    }
}

3. 运行结果

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2085573.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

护眼台灯是不是智商税?全面测评松下、书客、飞利浦护眼台灯!

在当今数字化时代,长时间面对电子屏幕已成为日常生活的一部分,这对我们的视力健康构成了挑战。特别是在学习和工作的场景中,一款优质的护眼台灯不仅能够提供舒适的照明环境,还能有效减轻眼睛疲劳,保护视力。然而&#…

如何优雅的使用责任链模式?

如何优雅的使用责任链模式? 在业务开发中,总是会由于需要处理复杂的业务逻辑,从而造成开发者的代码冗余或者模块之间耦合度过高,那么当面对这种情况时,如何实现请求处理的灵活性和可维护性,责任链模式就可以…

短视频流量|基于SprinBoot+vue的短视频流量数据分析系统(源码+数据库+文档)

短视频流量数据分析系统 基于SprinBootvue的短视频流量数据分析系统 一、前言 二、系统设计 三、系统功能设计 5.1 系统功能模块 5.2 管理员功能模块实现 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取: 博主介绍…

免费批量Excel文件合并、拆分工具

软件介绍 下载地址:https://pan.quark.cn/s/ae860a4e2ccb 1.多个XLS或XLSX格式EXCEL文件合并,合并后可使用数据透视表进行相关操作。 2.自动合并多个EXCEL文件的第一个工作表,并汇总成一张表,可根据所有列标题需要指定需要的列。 …

【基础篇】行锁功过:怎么减少行锁对性能的影响?

定义 **MySQL 的行锁是在引擎层由各个引擎自己实现的。**但并不是所有的引擎都支持行锁,比如 MyISAM 引擎就不支持行锁。不支持行锁意味着并发控制只能使用表锁,对于这种引擎的表,同一张表上任何时刻只能有一个更新在执行,这就会…

一文详解JNPF低代码平台在不同行业的应用分析

随着信息技术的飞速发展,企业对于快速开发和部署业务应用的需求日益增长。低代码平台作为加速企业数字化转型的利器,正受到越来越多的关注。JNPF作为一款先进的低代码开发平台,凭借其强大的功能和灵活性,在不同行业中得到了广泛的…

Jenkins安装使用详解,jenkins实现企业级CICD流程

文章目录 一、资料1、官方文档 二、环境准备1、安装jdk172、安装maven3、安装git4、安装gitlab5、准备我们的springboot项目6、安装jenkins7、安装docker8、安装k8s(可选,部署节点)9、安装Harbor10、准备带有jdk环境的基础镜像 三、jenkins实…

禁止文件外发 | 如何禁止员工外发文件?严守企业机密,禁止员工外发敏感文件!

近期,我们注意到一些敏感项目资料有外泄的风险,这对公司的核心竞争力构成了严重威胁! 我们必须立即采取行动,严守企业机密,确保每一份文件都安全无虞。 从今天起,我们要全面升级信息安全措施,…

Java基础(5)- Java代码笔记2

目录 一、键盘录入_Scanner 1.输入:导包 -> 创建对象 -> 调用方法 2.next和nextLine区别 二、Random随机数 1.生成随机数 2.在指定范围内随机生成一个数 三、Switch语句 四、一维数组 1.数组定义 2.获取数组长度 3.遍历数组 3.输出数组 4.数组常见…

[Backbone]CAS-ViT: Convolutional Additive Self-attention Vision Transformers

1. BaseInfo TitleCAS-ViT: Convolutional Additive Self-attention Vision Transformers for Efficient Mobile ApplicationsAdresshttps://arxiv.org/pdf/2408.03703Journal/Time202408Author清华Codehttps://github.com/Tianfang-Zhang/CAS-ViTRead20240829TableVisonTrans…

【健康问答】揭秘五大‘天然降压果‘,高血压患者常吃,血压稳稳降!-曹启富医生

曹医生,听说有些水果对高血压患者有特别的益处,能帮助降低血压,是真的吗? 曹医生说:确实如此。在日常饮食中,合理摄入一些富含特定营养素的水果,对于辅助控制高血压有着积极的作用。今天&#…

苹果手机系统崩溃了怎么办?详细修复指南助你快速恢复

苹果手机以其卓越的性能和稳定的系统赢得了众多用户的青睐,但偶尔也会出现系统崩溃的情况,让人措手不及。当面对苹果手机系统崩溃时,不必过于担心,本文将为你提供一套详细的修复指南,帮助你快速恢复手机的正常使用。 …

AI 网关零代码解决 AI 幻觉问题

作者:邢云阳,Higress Contributor 前言 什么是 AI Agent 随着大模型技术的快速发展,越来越多的公司在实际业务中落地了大模型应用。但是人们逐渐发现了大模型能力的不足。例如:由于大模型的训练数据是有限的,因此一…

身体发出的“高压”警报,曹启富医生教你识别高血压症状

高血压,这一慢性“隐形杀手”,正悄然影响着越来越多人的健康。随着生活节奏的加快和不良生活习惯的积累,其发病率逐年攀升,成为威胁人类健康的重要疾病之一。今天,我们有幸邀请到心脑血管科专家曹启富医生,…

摩博会15天倒计时!ONEOS 恒石智能强强联手,即将携多款MODEL系列芯片打造的智能仪表璀璨亮相

随着2024年第二十二届中国国际摩托车博览会(摩博会)的临近,国内领先的操作系统提供商ONEOS与智能硬件领域的佼佼者恒石智能宣布强强合作,将于9月13日至16日在重庆国家会展中心共同揭开多款MODEL系列芯片驱动的彩屏仪表的神秘面纱。…

JavaWeb - Vue项目

创建 命令行 vue create project 图形化界面 vue ui 目录结构 启动 命令行 npm run serve 端口配置 Vue的组件文件以.vue结尾 每个组件有三个部分组成&#xff1a; <template>&#xff1a;模板部分&#xff0c;由它生成HTML代码<script>&#xff1a;控制…

揭秘SQL注入漏洞:为何它成为攻击者的首选?

自Web应用程序开始广泛使用数据库以来&#xff0c;SQL注入漏洞便因其隐蔽性强、潜在危害巨大以及实施门槛相对较低等特性&#xff0c;成为了网络攻击者频繁利用的安全弱点之一。尽管这一漏洞已经存在多年&#xff0c;它仍然是企业组织在数字化转型过程中面临的最为普遍且危险的…

vue2项目 预渲染 Unable to prerender all routes 错误排查与解决方案

前言 今天在做我的Vue2项目的SEO优化时&#xff0c;我采用了prerender-spa-plugin与vue-meta-info的一套官网前端SEO预渲染方案。 但是&#xff0c;在打包时&#xff0c;报错Unable to prerender all routes。尝试了很多种网上方案&#xff0c;都没有成功&#xff0c;最后从源…

用代码和android studio创建flutter项目的区别差异

用代码创建的项目&#xff0c;在lib目录下&#xff0c;不会出现dictory文件夹&#xff0c;操作起来有些不便。

智慧灯塔,照亮企业AI Agent实施明路

AI Agent是能够感知环境&#xff0c;基于目标进行决策并执行动作的智能化应用。随着大模型能力增强以及RAG等技术的成熟&#xff0c;AI Agent的能力得到了质的飞跃。这些模型赋予了AI Agent更接近人类的思维能力&#xff0c;再联动各类工具和组件&#xff0c;使得AI Agent在处理…