c语言汉诺塔递归算法_C语言编程学习之递归实现汉诺塔图解!还有零基础入门视频~...

C语言是面向过程的,而C++是面向对象的

C和C++的区别:

C是一个结构化语言,它的重点在于算法和数据结构。C程序的设计首要考虑的是如何通过一个过程,对输入(或环境条件)进行运算处理得到输出(或实现过程(事务)控制)。

C++,首要考虑的是如何构造一个对象模型,让这个模型能够契合与之对应的问题域,这样就可以通过获取对象的状态信息得到输出或实现过程(事务)控制。 所以C与C++的最大区别在于它们的用于解决问题的思想方法不一样。之所以说C++比C更先进,是因为“ 设计这个概念已经被融入到C++之中 ”。

0a72ea491af6efc01492f1222b54486a.png

C与C++的最大区别:在于它们的用于解决问题的思想方法不一样。之所以说C++比C更先进,是因为“ 设计这个概念已经被融入到C++之中 ”,而就语言本身而言,在C中更多的是算法的概念。那么是不是C就不重要了,错!算法是程序设计的基础,好的设计如果没有好的算法,一样不行。而且,“C加上好的设计”也能写出非常好的东西。

C/C++编程学习笔记​zhuanlan.zhihu.com
b1dedf66059b551bda82968c00400217.png

✪ C语言编程学习之递归实现汉诺塔图解

8b05ba94d2a78525228a6279ce48087b.png

思路:移动过程中大盘子永远不能再小盘子上面。

///

//递归实现汉诺塔

假设A柱子上共有n个盘子,从上到下依次为1,2…n;

1、如果n=1,则将A上的盘子直接移到C上即可;

64aed064a6940d0a720b9926899e1a2d.png

2、如果n=2,则:

● 将A上的第1个盘子移到B;

● 将A上的第2个盘子移到C,此时B上一个盘子 ;

● 将B上的第1个盘子移到C。完成 。

378670d180c99e6d44699a146c7bd951.png

3、如果n=3,则:

● 首先将A上的上2个盘子借助C移动到B上,步骤:

✎ 将A上第1个盘子移到C;

✎ 将A上第2个盘子移到B;

✎ 将C上第1个盘子移到B;

● 将A上盘子3移动到C上;

● 将B上两个盘子借助A移动到C上,步骤:

✎ 将B上盘子1移动到A上;

✎ 将B上盘子2移动到C上;

✎ 将A上的盘子1移动到C上。完成!

bae495e20d95a81b3e42810341726381.png

● 可以总结出当n个盘子(n≥2)时,移动的过程如下:

✎ 将A上的n-1个盘子移动到B上;

✎ 将A上的第n个移动到C上;

✎ 将B上的n-1个盘子移动到C上;其中4.1和4.3是类同的。

5ec3f5ec639c90685dd258eafe0d9946.png

代码:

#include

1db931be5f184499a805149a3309a890.png

是不是很简单呢?如果你按照这种思路来写的话,相信凭你聪明才智很快就能写出来!

自学C/C++不易,此路应携手前行。

如果你想跟着小编一起学编程的话!

可以来我的C语言/C++编程学习基地,【点击进入】!

还有(源码,零基础教程,项目实战教学视频)【快来学习吧】!

697a72fb65cc24daaeb3025f7ef12ddf.png

3effcc554b885f160142145dfd8c9052.png
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值