| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> C++知识库 -> 关于用c函数递归实现打印汉诺塔移动步骤 -> 正文阅读 |
|
[C++知识库]关于用c函数递归实现打印汉诺塔移动步骤 |
提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 前言? 本人专科大一,,c/c++刷题,感觉递归这一块有的题理解起来挺抽象的,这是打印汉诺塔步骤的一道题,希望有不对的地方大家能够指正批评,加油!。 提示:以下是本篇文章正文内容,下面案例可供参考 一、汉诺塔是什么?示例:一 ? 汉诺塔(Tower of Hanoi),又称河内塔,是一个源于印度古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。 二、代码1.代码如下递归比较抽象,具体思路我会分开写。
2.分解思路要找规律,找汉诺塔移动以后相同的,可重复的局面。 找到后发现,如果把前N-1个盘子移动到另一个(目标)柱子上, 那么,有一个最大的盘子——N在原来的柱子(源)上, 此时,(源)柱子可用。再移动前N-1个盘子局面相同。 三根柱子作为: A:from(源)B:help(辅助)C:to(目标)身份是不断地在变化的。 例如:第一次想把N-1个汉诺塔盘子移动到B柱子上,那么B就变成了to(目标),C则变为了help(辅助)。?
移动后局面相同,继续移动前N-1个盘子。把C作为目标,A作为辅助。
如此往复,身份一直在变,但是移动完成后的局面都是相同的,利用这个思路写出递归函数。 总结以上就是今天学习的内容了,虽然花了很长时间去理解,最后找到了一个自己能理解的方式去记忆,但是别人能想出来的事情我们也一定可以,而且勤能补拙,希望大家能坚持学习下去,一起进步。加油! 最后送给大家一句话——“世上的事,只要肯用心学,没有一件是太晚的!”
第一条递归回来走第一条代码时to和help身份互换,和嵌套循环类似? |
|
C++知识库 最新文章 |
【C++】友元、嵌套类、异常、RTTI、类型转换 |
通讯录的思路与实现(C语言) |
C++PrimerPlus 第七章 函数-C++的编程模块( |
Problem C: 算法9-9~9-12:平衡二叉树的基本 |
MSVC C++ UTF-8编程 |
C++进阶 多态原理 |
简单string类c++实现 |
我的年度总结 |
【C语言】以深厚地基筑伟岸高楼-基础篇(六 |
c语言常见错误合集 |
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 | -2025/1/9 14:54:49- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |