从汉诺塔看递归

本文通过介绍汉诺塔问题,深入探讨了递归的概念。作者以代码为例,解释了递归函数如何处理汉诺塔问题,并强调了递归在解决复杂问题时的思维价值,尽管它可能对初学者来说较为抽象。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    刚入门算法,首先接触到的就是递归。在网上查了一下,几乎都说递归特别简单,弄得我心里慌得不得了,我就在想:为什么我感觉递归总是不懂,这感觉不对劲啊!但也没过分追求,不懂就不懂吧,回头再说。今天有空,就把这个当初看到的汉诺塔问题写一下,总结总结,问题什么的就不多说了,直接上代码(这代码是借鉴别人的)。

#include <iostream>
using namespace std;

int m = 0;        //标记移动次数
					
void move(int disks, char N, char M) 
{
		cout<<"第" << (++m) << " 次移动 :   " << " 把 " << disks << " 号圆盘从 " << N << " ->移到->  " << M<<endl;
}
void hanoi(int n, char A, char B, char C)   //n为汉诺塔的个数,A,B,C分别为三个塔
{
		if (n == 1)                           
			move(1, A, C);                    //圆盘只有一个时,只需将其从A塔移到C塔
		else 
		{
			hanoi(n - 1, A, B, C);            
			move(n, A, B);                    
			hanoi(n - 1, B, C, A);            
		}	
}
int main() 
{
		char A = 'A&#
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值