【Python/C++ 递归】汉诺塔

汉诺塔(Tower of Hanoi),又称河内塔,是一个源于印度古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘

在这里插入图片描述
1.游戏规则
条件: 有A、B、C三根柱子,A柱子按照上小下大放置圆盘。
规则: 每次只能移动1个圆盘,圆盘可在A、B、C三根柱子间任意移动,并且始终保持小盘在大盘上。
目标: 圆盘全部从A柱移动到C柱上,并且圆盘顺序不变,依旧是上小下大。
2.汉诺塔1-3层详解
汉诺塔是一道非常经典的递归问题,对于递归问题的求解,最重要的是找到递归公式,下面我们先通过观察1-3层汉诺塔移动方法,看看能不能找到一些规律。
🍑(1)一层汉诺塔
在这里插入图片描述
一层汉诺塔移动方法是:
移动第1个圆盘: A -> C

🍑(2)二层汉诺塔
在这里插入图片描述
二层汉诺塔移动方法:
移动第1个圆盘: A -> B
移动第2个圆盘: A -> C
移动第1个圆盘: B -> C

🍑(3)三层汉诺塔
在这里插入图片描述
三层汉诺塔移动方法:

移动第1个圆盘: A -> C
移动第2个圆盘: A -> B
移动第1个圆盘: C -> B
移动第3个圆盘: A -> C
移动第1个圆盘: B -> A
移动第2个圆盘: B -> C
移动第1个圆盘: A -> C

动图:

在这里插入图片描述
3.汉诺塔求解思路
观察过上面1-3层的汉诺塔的移动,你有没有找到一些规律呢?经过简单的归纳总结,我们大体可以得到这样的规律:

当汉诺塔层数n为1时:

将A柱上的1个圆盘直接挪到C柱上
当汉诺塔层数n为2时:

步骤1:先将A柱上第1个圆盘移动到B柱上
步骤2:再将A柱上剩下的1个圆盘直接移动到C柱上
步骤3:最后将B柱上的圆盘移动到C柱上

当汉诺塔层数n为3时:

步骤1:先将A柱上前2个圆盘移动到B柱上
步骤2:再将A柱上剩下的1个圆盘直接移动到C柱上
步骤3:最后将B柱上的圆盘移动到C柱上

那么当n=4的时候呢?

我们按照上述过程,可以想到这样的思路:

步骤1:先将前4-1个圆盘,从A柱借助C柱挪到B柱
步骤2:再将A柱上剩下的1个圆盘,从A柱直接挪到C柱
步骤3:最后将B柱上的4-1个圆盘,从B柱借助A柱挪到C柱

通过对上述过程的归纳,当为n层汉诺塔的时候,我们将其分为三步:

步骤1:先将前n-1个圆盘,从A柱借助C柱挪到B柱
步骤2:再将A柱上剩下的1个圆盘,从A柱直接挪到C柱
步骤3:最后将B柱上的n-1个圆盘,从B柱借助A柱挪到C柱

python 递归方式解汉洛塔问题:

def hanoi(n, a, b, c):
    if n == 1:
        print(f"Move disk 1 from {a} to {c}")
    else:
        hanoi(n-1, a, c, b)
        print(f"Move disk {n} from {a} to {c}")
        hanoi(n-1, b, a, c)

# 测试代码
n = 3
hanoi(n, 'A', 'B', 'C')

练习题:
【空汽水瓶】

题目描述

有这样一道智力题:“某商店规定:三个空汽水瓶可以换一瓶汽水。小张手上有十个空汽水瓶,她最多可以换多少瓶汽水喝?”答案是5瓶,方法如下:先用9个空瓶子换3瓶汽水,喝掉3瓶满的,喝完以后4个空瓶子,用3个再换一瓶,喝掉这瓶满的,这时候剩2个空瓶子。然后你让老板先借给你一瓶汽水,喝掉这瓶满的,喝完以后用3个空瓶子换一瓶满的还给老板。如果小张手上有n个空汽水瓶,最多可以换多少瓶汽水喝?

输入:

输入文件最多包含10组测试数据,每个数据占一行,仅包含一个正整数n(1<=n<=100),表示小张手上的空汽水瓶数。n=0表示输入结束,你的程序不应当处理这一行。

输出:

对于每组测试数据,输出一行,表示最多可以喝的汽水瓶数。如果一瓶也喝不到,输出0。

样例输入:
3
10
81
0

样例输出:
1
5
40

C++ 代码

#include<stdio.h>
int fun(int num){
    int nn,m,n,all=0;//nn表示换了之后有水的瓶子数
    //m表示换了之后空的瓶子数,all共可以喝到的水。 
    nn=num/3;
    m=num%3;
    n=nn+m;
    all=all+nn;
     
    if(n>=3){
    all=nn+fun(n); 
    }else if(n==2){
    all++;
    }
    return all; 
}
int main(){
    int num,a;
    int i=10;
    while(i){
    scanf("%d",&num);
    if(1<=num&&num<=100){
    a=fun(num);
    printf("%d\n",a);
    }
    if(num==0)break;
    i--;
    }
    return 0;
}
 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

腾讯智影数字人工具

腾讯智影数字人工具 腾讯智影数字人的形象风格多样&#xff0c;包括写实、卡通等&#xff0c;可以满足不同年龄层观众的喜好。同时&#xff0c;腾讯智影数字人也提供了灵活的驱动方案&#xff0c;可以通过文本或配音直接生成视频&#xff0c;并支持数字人做出与视频一样的动作…

企业如何实现降本增效——数字化转型

说到企业数字化转型&#xff0c;不可避免要围绕企业降本增效。企业们都在积极寻找降本增效解决之道&#xff0c;以实现降本增效的目标。数字化转型也成为了很多企业降本增效的重要手段。通过引入云计算、大数据、人工智能等技术&#xff0c;企业们实现了业务流程的数字化和智能…

YOLOv8-seg改进:注意力系列篇 | 一种简单有效的可变形的自注意力模块DAT | CVPR 2022

🚀🚀🚀本文改进:Deformable Attention Transformer,一种简单有效的可变形的自注意力模块,增强sparse attention 的表征能⼒; 🚀🚀🚀DAT小目标分割&复杂场景首选,实现涨点 🚀🚀🚀YOLOv8-seg创新专栏:http://t.csdnimg.cn/KLSdv 学姐带你学习YOL…

企业视频数字人有哪些应用场景

来做个数字人吧&#xff0c;帮我干点活吧。 国内的一些数字人&#xff1a; 腾讯智影 腾讯智影数字人是一种基于人工智能技术的数字人物形象&#xff0c;具有逼真的外观、语音和行为表现&#xff0c;可以应用于各种场景&#xff0c;如新闻播报、文娱推介、营销、教育等。 幻…

GMS CTS测试命令汇总

目录 跑CTS之前的准备 样机环境要求 跑各模块版本要求 CTS 简介 复测上轮的失败项 多台设备测试 单跑指定模块和测试用例 GTS VTS STS GSI 获取fingerprint 跑CTS之前的准备 样机环境要求 1、打开stay wake&#xff08;保持屏幕常亮&#xff09;、OEM unlocking、…

物联网赋能:WIFI HaLow在无线连接中的优势

在探讨无线网络连接时&#xff0c;我们不难发现&#xff0c;WIFI已经成为我们日常生活中不可或缺的一部分&#xff0c;承载了半数以上的互联网流量&#xff0c;并在家庭、学校、娱乐场所等各种场合广泛应用。然而&#xff0c;尽管WIFI4、WIFI5和WIFI6等协议无处不在&#xff0c…

文心一言-情感关怀之旅

如何让LLM更有温度。 应用介绍

OpenAI 变天:Sam Altman 被踢出局,原 CTO 暂代临时 CEO

文章目录 灵魂人物 Sam Altman 离任 OpenAICEO 下台&#xff1a;OpenAI 也宫斗&#xff1f;个人简介 hello&#xff0c;大家好&#xff0c;我是 Lorin&#xff0c;一觉醒来科技圈发生了一件令人震惊的大事&#xff1a;Sam Altman 被踢出局&#xff0c;原 CTO 暂代临时 CEO。 灵…

基于蛾群算法优化概率神经网络PNN的分类预测 - 附代码

基于蛾群算法优化概率神经网络PNN的分类预测 - 附代码 文章目录 基于蛾群算法优化概率神经网络PNN的分类预测 - 附代码1.PNN网络概述2.变压器故障诊街系统相关背景2.1 模型建立 3.基于蛾群优化的PNN网络5.测试结果6.参考文献7.Matlab代码 摘要&#xff1a;针对PNN神经网络的光滑…

【Mysql】复合查询详解+实战操作(多表查询、自链接、子查询等)

&#x1f308;欢迎来到Python专栏 &#x1f64b;&#x1f3fe;‍♀️作者介绍&#xff1a;前PLA队员 目前是一名普通本科大三的软件工程专业学生 &#x1f30f;IP坐标&#xff1a;湖北武汉 &#x1f349; 目前技术栈&#xff1a;C/C、Linux系统编程、计算机网络、数据结构、Mys…

突发!“ChatGPT 之父”奥特曼被 OpenAI 开除!!乔布斯故事重演了?

重磅消息&#xff01; OpenAI刚刚官宣领导层换届&#xff0c;SamAltman辞任CEO并离开董事会&#xff0c;原CTO Mira Murati 任命为临时CEO&#xff0c;并正在进行寻找永久继任CE0。 大模型研究测试传送门 GPT-4传送门&#xff08;免墙&#xff0c;可直接测试&#xff0c;遇浏…

【快速解决】实验三 简单注册的实现《Android程序设计》实验报告

目录 前言 实验要求 实验三 简单注册的实现 实验目的&#xff1a; 实验内容&#xff1a; 实验提示&#xff1a; 无 三、遇到的问题总结&#xff08;如果有问题&#xff0c;请总结。如果没问题请写“无”&#xff09; 正文开始 第一步建立项目 第二步选择empty views a…

IDEA 中设置 File Header 以及自定义类、方法注释模板的方法

目录 1 设置 File Header2 自定义类、方法注释生成类注解模板生成方法注解模板 1 设置 File Header File -> Settings -> File and Code Templates -> Includes -> File Header -> 编辑 2 自定义类、方法注释 File -> Settings -> Live Templates -&g…

Reflect的作用,target,property,value,receiver代表啥

1.真的proxy let target {name:张三} let handler {get(target,property,receiver){console.log(1,target,2,property,3,receiver)return Reflect.get(target,property,receiver)},set(target,property,value,receiver){console.log(a,target,b,property,c,value,d,receiver)…

java每日一记 —— 谈谈反射

这应该是基础吧 1.先来说点前置知识&#xff1a;类的加载机制2.以自己的方式来谈反射的概念3.获取class的三种方式3.1.通过已知的类型获取class3.2.通过实例对象获取class3.3.通过Class.forName获取全路径指定类名的class 4.整理了一下API&#xff1a;坦言说&#x1faa1;累5.现…

利用X6 制作一个简单的流程图工具

介绍 项目模版使用 我自己基于 arco-design 封装的一个 B 端项目模版 。 地址&#xff1a;https://github.com/duKD/antv-x6-org 运用 antv/X6 &#xff1a; https://x6.antv.antgroup.com/ 来实现 一个简单的流程图工具 项目预览&#xff1a; 功能 支持框选 alt鼠标左键…

记一次用jlink调试正常,不进入调试就不能运行的情况

一、概述 我开机会闪烁所有指示灯&#xff0c;但是重新上电时&#xff0c;指示灯并没有闪烁&#xff0c;就像"卡死"了一样。 使用jlink的swd接口进行调试&#xff0c;需要多点几次运行才能跳转到main函数里面。 调试模式第一次点击运行&#xff0c;暂停查看函数堆栈…

iframe父子页面通信相互调用传递参数多个postMessage

效果 如何运行 父页面代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title>…

PyTorch DataLoader整理函数详解【collate_fn】

DataLoader 是 PyTorch 中最常用的类之一。 而且&#xff0c;它是你首先学习的内容之一。 该类有很多参数&#xff0c;但最有可能的是&#xff0c;你将使用其中的大约三个参数&#xff08;dataset、shuffle 和 batch_size&#xff09;。 今天我想解释一下 collate_fn 的含义—根…

【开源】基于JAVA的校园失物招领管理系统

项目编号&#xff1a; S 006 &#xff0c;文末获取源码。 \color{red}{项目编号&#xff1a;S006&#xff0c;文末获取源码。} 项目编号&#xff1a;S006&#xff0c;文末获取源码。 目录 一、摘要1.1 项目介绍1.2 项目录屏 二、研究内容2.1 招领管理模块2.2 寻物管理模块2.3 系…